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1.0 INTRODUCTION 

The term "microcomputer" has been used to describe virtually every type of small computing device 
designed within the last few years. This term has been applied to everything from simple "microprogram- 
med" controllers constructed out of TTL MSI up to low end minicomputers with a portion of the CPU 
constructed out of TTL LSI "bit slices." However, the major impact of the LSI technology within the last 
few years has been with MOS LSI. With this technology, it is possible to fabricate complete and very power- 
ful computer systems with only a few MOS LSI components. 

The Zilog Z-80 family of components is a significant advancement in the state-of-the art of micro- 
computers. These components can be configured with any type of standard semiconductor memory to 
generate computer systems with an extremely wide range of capabilities. For example, as few as two LSI 
circuits and three standard TTL MSI packages can be combined to form a simple controller. With additional 
memory and I/O devices a computer can be constructed with capabilities that only a minicomputer could 
previously deliver. This wide range of computational power allows standard modules to be constructed by a 
user that can satisfy the requirements of an extremely wide range of applications. 

The major reason for MOS LSI domination of the microcomputer market is the low cost of 
these few LSI components. For example, MOS LSI microcomputers have already replaced TTL logic in 
such applications as terminal controllers, peripheral device controllers, traffic signal controllers, point of 
sale terminals, intelligent terminals and test systems. In fact the MOS LSI microcomputer is finding its way 
into almost every product that now uses electronics and it is even replacing many mechanical systems such 
as weight scales and automobile controls. 

The MOS LSI microcomputer market is already well established and new products using them are 
being developed at an extraordinary rate. The Zilog Z-80 component set has been designed to fit into 
this market through the following factors: 

1. The Z-80 is fully software compatible with the popular 8080A CPU offered from several sources. 
Existing designs can be easily converted to include the Z-80 as a superior alternative. 

2. The Z-80 component set is superior in both software and hardware capabilities to any other micro- 
computer system on the market. These capabilities provide the user with significantly lower hardware 
and software development costs while also allowing him to offer additional features in his system. 

3. For increased throughput the Z80A operating at a 4 MHZ clock rate offers the user significant speed 
advantages over competitive products. 

4. A complete product line including full software support with strong emphasis on high level languages 
and a disk-based development system with advanced real-time debug capabilities is offered to enable 
the user to easily develop new products. 

Microcomputer systems are extremely simple to construct using Z-80 components. Any such system 
consists of three parts: 

1. CPU (Central Processing Unit) 

2. Memory 

3. Interface Circuits to peripheral devices 

The CPU is the heart of the system. Its function is to obtain instructions from the memory and perform 
the desired operations. The memory is used to contain instructions and in most cases data that is to be 
processed. For example, a typical instruction sequence may be to read data from a specific peripheral 
device, store it in a location in memory, check the parity and write it out to another peripheral device. Note 
that the Zilog component set includes the CPU and various general purpose I/O device controllers, while a 
wide range of memory devices may be used from any source. Thus, all required components can be 
connected together in a very simple manner with virtually no other external logic. The user's effort then 
becomes primarily one of software development. That is, the user can concentrate on describing his prob- 
lem and translating it into a series of instructions that can be loaded into the microcomputer memory. Zilog 
is dedicated to making this step of software generation as simple as possible. A good example of this is our 



assembly language in which a simple mnemonic is used to represent every instruction that the CPU can 
perform. This language is self documenting in such a way that from the mnemonic the user can understand 
exactly what the instruction is doing without constantly checking back to a complex cross listing. 



2.0 Z-80 CPU ARCHITECTURE 



A block diagram of the internal architecture of the Z-80 CPU is shown in figure 2.0-1. The diagram 
shows all of the major elements in the CPU and it should be referred to throughout the following 
description. 
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2.1 CPU REGISTERS 

The Z-80 CPU contains 208 bits of R/W memory that are accessible to the programmer. Figure 2.0-2 
illustrates how this memory is configured into eighteen 8-bit registers and four 16-bit registers. All Z-80 
registers are implemented using static RAM. The registers include two sets of six general purpose registers 
that may be used individually as 8-bit registers or in pairs as 16-bit registers. There are also two sets of 
accumulator and flag registers. 



Special Purpose Registers 

1. Program Counter (PC). The program counter holds the 16-bit address of the current instruction being 
fetched from memory. The PC is automatically incremented after its contents have been transferred 
to the address lines. When a program jump occurs the new value is automatically placed in the PC, 
overriding the incrementer. 

2. Stack Pointer (SP). The stack pointer holds the 16-bit address of the current top of a stack located 
anywhere in external system RAM memory. The external stack memory is organized as a last-in first- 
out (LIFO) file. Data can be pushed onto the stack from specific CPU registers or popped off of the 
stack into specific CPU registers through the execution of PUSH and POP instructions. The data 
popped from the stack is always the last data pushed onto it. The stack allows simple implementation 
of multiple level interrupts, unlimited subroutine nesting and simplification of many types of data 
manipulation. 
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Two Index Registers (DC & IY). The two independent index registers hold a 16-bit base address that 
is used in indexed addressing modes. In this mode, an index register is used as a base to point to a 
region in memory from which data is to be stored or retrieved. An additional byte is included in 
indexed instructions to specify a displacement from this base. This displacement is specified as a two's 
complement signed integer. This mode of addressing greatly simplifies many types of programs, 
especially where tables of data are used. 

4. Interrupt Page Address Register (I). The Z-80 CPU can be operated in a mode where an indirect call 
to any memory location can be achieved in response to an interrupt. The I Register is used for this 
purpose to store the high order 8-bits of the indirect address while the interrupting device provides the 
lower 8-bits of the address. This feature allows interrupt routines to be dynamically located anywhere 
in memory with absolute minimal access time to the routine. 

5. Memory Refresh Register (R). The Z-80 CPU contains a memory refresh counter to enable dynamic 
memories to be used with the same ease as static memories. Seven bits of this 8 bit register are auto- 
matically incremented after each instruction fetch. The eighth bit will remain as programmed as the 
result of an LD R, A instruction. The data in the refresh counter is sent out on the lower portion of 
the address bus along with a refresh control signal while the CPU is decoding and executing the fetched 
instruction. This mode of refresh is totally transparent to the programmer and does not slow down the 
CPU operation. The programmer can load the R register for testing purposes, but this register is normally 
not used by the programmer. During refresh, the contents of the I register are placed on the upper 8 bits of 
the address bus. 



Accumulator and Flag Registers 

The CPU includes two independent 8-bit accumulators and associated 8-bit flag registers. The accumu- 
lator holds the results of 8-bit arithmetic or logical operations while the flag register indicates specific 
conditions for 8 or 16-bit operations, such as indicating whether or not the result of an operation is equal 
to zero. The programmer selects the accumulator and flag pair that he wishes to work with with a single 
exchange instruction so that he may easily work with either pair. 



General Purpose Registers 

There are two matched sets of general purpose registers, each set containing six 8-bit registers that 
may be used individually as 8-bit registers or as 16-bit register pairs by the programmer. One set is called 
BC, DE and HL while the complementary set is called BC, DE' and HL'. At any one time the programmer 
can select either set of registers to work with through a single exchange command for the entire set. In 
systems where fast interrupt response is required, one set of general purpose registers and an accumulator/ 
flag register may be reserved for handling this very fast routine. Only a simple exchange commands need be 
executed to go between the routines. This greatly reduces interrupt service time by eliminating the require- 
ment for saving and retrieving register contents in the external stack during interrupt or subroutine process- 
ing. These general purpose registers are used for a wide range of applications by the programmer. They also 
simplify programming, especially in ROM based systems where little external read/write memory is 
available. 



2.2 ARITHMETIC & LOGIC UNIT (ALU) 

The 8-bit arithmetic and logical instructions of the CPU are executed in the ALU. Internally the ALU 
communicates with the registers and the external data bus on the internal data bus. The type of functions 
performed by the ALU include: 

Add Left or right shifts or rotates (arithmetic and logical) 

Subtract Increment 

Logical AND Decrement 

Logical OR Set bit 

Logical Exclusive OR Reset bit 

Compare Test bit 

2.3 INSTRUCTION REGISTER AND CPU CONTROL 

As each instruction is fetched from memory, it is placed in the instruction register and decoded. The 
control sections performs this function and then generates and supplies all of the control signals necessary 
to read or write data from or to the registers, control the ALU and provide all required external control 
signals. 



-BLANK- 



-6- 



3.0 Z-80 CPU PIN DESCRIPTION 

The Z-80 CPU is packaged in an industry standard 40 pin Dual In- Line Package. The I/O pins are shown 
in figure 3.0-1 and the function of each is described below. 
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D -D ? 
(Data Bus) 



Tri-state output, active high. A Q -Aj 5 constitute a 16-bit address bus. The 
address bus provides the address for memory (up to 64K bytes) data 
exchanges and for I/O device data exchanges. I/O addressing uses the 8 lower 
address bits to allow the user to directly select up to 256 input or 256 output 
ports. Aq is the least significant address bit. During refresh time, the lower 
7 bits contain a valid refresh address. 

Tri-state input/ output, active high. D0-D7 constitute an 8-bit bidirectional 
data bus. The data bus is used for data exchanges with memory and I/O 
devices. 



M 



(Machine Cycle one) 



MREQ 

(Memory Request) 



Output, active low. Mj indicates that the current machine cycle is the OP 
code fetch cycle of anjnstruction execution. Note that during execution 
of 2-byte op-codes, Ml is generated as each op code byte is fetched. These 
two byte o p-codes always begin with CBH, DDH, EDH or FDH. Ml also 
occurs with IORQ to indicate an interrupt acknowledge cycle. 

Tri-state output, active low. The memory request signal indicates that the 
address bus holds a valid address for a memory read or memory write 
operation. 



IORQ 

(Input/Output Request) 



Tri-state output, active low. The IORQ signal indicates that the lower half of 
the add ress bus holds a valid I/O address for a I/O read or write operation. An 
IORQ signal is also generated with an Ml signal when an interrupt is being 
acknowledged to indicate that an interrupt response vector can be placed on 
the data bus. Interrupt Acknowledge operations occur during Mj time while 
I/O operations never occur during Mj time. 



RD 

(Memory Read) 



Tri-state output, active low. RD indicates that the CPU wants to read data 
from memory or an I/O device. The addressed I/O device or memory should 
use this signal to gate data onto the CPU data bus. 



WR 

(Memory Write) 



Tri-state output, active low. WR indicates that the CPU data bus holds valid 
data to be stored in the addressed memory or I/O device. 



RFSH 

(Refresh) 



Output, active low. RFSH indicates that the lower 7 bits of the address 



bus contain a refresh address for dynamic memories and the current MREQ 
signal should be used to do a refresh read to all dynamic memories. 



HALT 

(Halt state) 



Output, active low. HALT indicates that the CPU has executed a HALT soft- 
ware instruction and is awaiting either a non maskable or a maskable inter- 
rupt (with the mask enabled) before operation can resume. While halted, the 
CPU executes NOP's to maintain memory refresh activity. 



WAIT 

(Wait) 



Input, active low. WAIT indicates to the Z-80 CPU that the addressed 
memory or I/O devices are not ready for a data transfer. The CPU continues 
to enter wait states for as long as this signal is active. This signal allows 
memory or I/O devices of any speed to be synchronized to the CPU. 



INT 

(Interrupt Request) 



Input, active low. The Interrupt Request signal is generated by I/O devices. A 
request will be honored at the end of the current instruction if the- internal 
software controlled interrupt enable flip-flop (IFF) is enabled and if the 
BUSRQ sig nal is no t active. When the CPU accepts the interrupt, an acknowl- 
edge signal (IORQ during Mj time) is sent out at the beginning of the next 
instruction cycle. The CPU can respond to an interrupt in three different 
modes that are described in detail in section 5.4 (CPU Control Instructions). 



NMI 

(Non Maskable 

Interrupt) 



Input, negative edge trigg ered. The non maskable interrupt request line has a 
higher priority than INT and is always recognized at the end of the cur rent 
instruction, independent of the status of the interrupt enable flip-flop. NMI 
automatically forces the Z-80 CPU to restart to location 0066^. The program 
counter is automatically saved in the external stack so that the user can return 
to the program that was interrupted. Note that continu ous WAI T cycles can 
p reven t the current instruction from ending, and that a BUSRQ will override 
a NMI. 



RESET Input, active low. RESET forces the program counter to zero and initializes 

the CPU. The CPU initialization includes: 

1) Disable the interrupt enable flip-flop 

2) Set Register I = 00 H 

3) Set Register R = 00 R 

4) Set Interrupt Mode 

During reset time, the address bus and data bus go to a high impedance state 
and all control output signals go to the inactive state. 



BUSRQ Input, active low. The bus request signal is used to request the CPU address 

(Bus Request) bus, data bus and tri-state output control signals to go to a high im pedance 

state so that other devices can control these buses. When BUSRQ is activated, 
the CPU will set these buses to a high impedance state as soon as the current 
CPU machine cycle is terminated. 



BUSAK Output, active low. Bus acknowledge is used to indicate to the requesting 

(Bus Acknowledge) device that the CPU address bus, data bus and tri-state control bus signals 

have been set to their high impedance state and the external device can now 

control these signals, 

$ Single phase TTL level clock which requires only a 330 ohm pull-up resistor 

to +5 volts to meet all clock requirements.. 
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4.0 CPU TIMING 

The Z-80 CPU executes instructions by stepping through a very precise set of a few basic operations. 
These include: 

Memory read or write 

I/O device read or write 

Interrupt acknowledge 

All instructions are merely a series of these basic operations. Each of these basic operations can take from 
three to six clock periods to complete or they can be lengthened to synchronize the CPU to the speed of 
external devices. The basic clock periods are referred to as T cycles and the basic operations are referred to 
as M (for machine) cycles. Figure 4.0-0 illustrates how a typical instruction will be merely a series of 
specific M and T cycles. Notice that this instruction consists of three machine cycles (Ml, M2 and M3). The 
first machine cycle of any instruction is a fetch cycle which is four, five or six T cycles long (unless length- 
ened by the wait signal which will be fully described in the next section). The fetch cycle (Ml) is used to 
fetch the OP code of the next instruction to be executed. Subsequent machine cycles move data between 
the CPU and memory or I/O devices and they may have anywhere from three to five T cycles (again they 
may be lengthened by wait states to synchronize the external devices to the CPU). The following para- 
graphs describe the timing which occurs within any of the basic machine cycles. In section 7, the exact 
timing for each instruction is specified. 
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BASIC CPU TIMING EXAMPLE 
FIGURE 4.0-0 



All CPU timing can be broken down into a few very simple timing diagrams as shown in figure 4.0-1 
through 4.0-7. These diagrams show the following basic operations with and without wait states (wait states 
are added to synchronize the CPU to slow memory or I/O devices). 

4.0-1. Instruction OP code fetch (Ml cycle) 

4.0-2. Memory data read or write cycles 

4.0-3. I/O read or write cycles 

4.04. Bus Request/ Acknowledge Cycle 

4.0-5. Interrupt Request/ Acknowledge Cycle 

4.0-6. Non maskable Interrupt Request/ Acknowledge Cycle 

4.0-7. Exit from a HALT instruction 
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INSTRUCTION FETCH 



Figure 4.0-1 shows the timing during an Ml cycle (OP code fetch). Notice th at the PC is placed on the 
address bus at the beginning of the Ml cycle. One half clock time later the MREQ signal go es active. At this 
time the address to the memory has had time to stabilize so that the falling edge of MREQ can be used 
directly as a chip enable clock to dynamic memories. The RD line also goes active to indicate that the 
memory read data should be enabled onto the CPU data bus. The CPU samples the data from the memory on 
the data bu s with the rising edge of the clock of state T3 and this same edge is used by the CPU to turn off 
the RD and MRQ signals. Thus the data has already been sampled by the CPU before the RD signal becomes 
inactive. Clock state T3 and T4 of a fetch cycle are used to refresh dynamic memories. (The CPU uses this 
time to decode and execute the fetched instruction so that no other operation could be performed at this 
time). During T3 and T4 the lower 7 bits of the address bus contain a memory refresh address and the RFSH 
signal becomes active to indicate that a refresh read of all dynamic memories should be accomplished. Notice 
that a RD signal is not generated d uring ref resh time to prevent data from different memory segments from 
being gated onto the data bus. The MREQ signal during refresh time should be used to perform a refresh read 
of all memory elements . The re fresh signal can not be used by itself since the refresh address is only guaran- 
teed to be stable during MREQ time. 
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FIGURE 4.0-1 



Figure 4.0-1 A illustrates how the fetch cycle is d elayed if the memory activates the WAIT li ne. Dur - 
ing T2 and every subsequent Tw, the CPU samples the WAIT line with the falling edge of $. If the WAIT 
line is active at this time, another wait state will be entered during the following cycle. Using this technique 
the read cycle can be lengthened to match the access time of any type of memory device. 
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MEMORY READ OR WRITE 

Figure 4.0-2 illustrates the timing of memory read or write cycles other than an OP code fetch (M i 
cycle). These cycles are g enerally three clock periods long unless wait states are requested by the memory 
via the WAIT signal. The MR EQ sign al and the RD signal are used the same as in the fetch cycle. In the case 
of a memory write cycle, the MREQ also becomes active when the address bus is stable so that it can be 
used directly as a chip enable for dynamic memories. The WR line is active when data on the data bus is 
stable so that it can b e used directly as a R/W pulse to virtually any type of semiconductor memory. 
Furthermore the WR signal goes inactive one half T state before the address and data bus contents are 
changed so that the overlap requirements for virtually any type of semiconductor memory type will be met. 
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Figure 4.0-2 A illustrates how a WAIT request signal will lengthen any memory read or write opera- 
tion. This operation is identical to that previously described for a fetch cycle. Notice in this figure that a 
separate read and a separate write cycle are shown in the same figure although read and write cycles can 
never occur simultaneously. 
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MEMORY READ OR WRITE CYCLES WITH WAIT STATES 
FIGURE 4.0-2A 



INPUT OR OUTPUT CYCLES 

Figure 4.0-3 illustrates an I/O read or I/O write operation. Notice that during I/O operations a single 
wai t state is automatically inserted. The reason for this is t hat dur ing I/O operations, the time from when 
the IORQ signal goes active until the CPU must sample the WAIT line is very short and without this extra 
state sufficient time does not exist for an I/O port to decode its address and activate the WAIT line if a wait 
is required. Also, without this wait state it is diffi cult to design MOS I/O devices that can operate at full 
CPU speed. During this wait state time the WAIT request signal is sampled. During a read I/O operation, 
the RD line is used to en able t he addressed port onto the data bus just as in the case of a memory read. For 
I/O write operations, the WR line is used as a clock to the I/O port, again with sufficient overlap timing 
automatically provided so that the rising edge may be used as a data clock. 



Figure 4.0-3A illustrates how additional wait states may be added with the WAIT line. The operation 
is identical to that previously described. 

BUS REQUEST/ ACKNOWLEDGE CYCLE 



Figure 4.04 illustrates the timing for a Bus Request/Acknowledge cycle. The BUSRQ s ignal is 
sampled by the CPU with the rising edge of the last clock period of any machine cycle. If the BUSRQ 
signal is active, the CPU will set its address, data and tri-state control signals to the high impedance state 
with the rising edge of the next clock pulse. At that time any external device can control the buses to 
transfer data between memory and I/O devices. (This is generally known as Direct Memory Access [DMA] 
using cycle stealing). The maximum time for the CPU to respond to a bus request is the length of a machine 
cycle and the external controller can maintain control of the bus for as many clock cycles as is desired. 
Note, however, that if very long DMA cycles are used, and dynamic memories are being used, the external 
controller must also perform the refresh function. This situation only occurs if very large blocks of data are 
transferred unde r DM A co ntrol Also note that during a bus request cycle, the CPU cannot be interrupted 
by either a NMI or an INT signal. 
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INTERRUPT REQUEST/ACKNOWLEDGE CYCLE 

Figure 4.0-5 illustrates the timing associated with an interrupt cycle. The interrupt signal (INT) is 
sampled by the CPU with the rising edge of the last clock at the end of any instruction. The signal will not be 
accepted if the internal CPU software controlled interrupt enable flip-flop is not set or if the BUSRQ signal 
is active. When the signal is accepted a speci al Ml cy cle is generated. During this special Ml cycle the IORQ 
signal becomes active (instead of the normal MREQ) to indicate that the interrupting device can place an 
8-bit vector on the data bus. Notice that two wait states are automatically added to this cycle. These states 
are added so that a ripple priority interrupt scheme can be easily implemented. The two wait states allow 
sufficient time for the ripple signals to stabilize and identify which I/O device must insert the response 
vector. Refer to section 8.0 for details on how the interrupt response vector is utilized by the CPU. 
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Figures 4.0-5 A and 4.0-5B illustrate how a programmable counter can be used to extend interrupt 
acknowledge time. (Configured as shown to add one wait state) 



Ml 



74S04 

t> 
[> 



IORQ 



D> 



n 



-o 



> 
> 



IORQ' 



(TO 
PERIPHERAL) 



7432 JO 



(TO CPU) 



LOAD DN/UP G 

74LS191 Q D 

A B C D 



+5V ^W*- 



O + O 



Ml O 



7432 ]( 



74S04 




EXTENDING INTERRUPT ACKNOWLEDGE TIME WITH WAIT STATE 

FIGURE 4.0-5A 



LAST T STATE OF 

LAST M CYCLE OF 

INSTRUCTION 



INT 



A n -A 



0"""15 



M1 



IORQ 



IORQ' 



DATA BUS 



WAIT 



AUTOMATIC WAIT ■ 



USER WAIT 
T w 



■Jv. 



NORMAL ACKNOWLEDGE 
TIME 



ACKNOWLEDGE TIME WITH ONE 
ADDITIONAL WAIT STATE 



-cz> 



REQUEST/ACKNOWLEDGE CYCLE WITH ONE ADDITIONAL WAIT STATE 

FIGURE 4.0-5B 



17 



NON MASKABLE INTERRUPT RESPONSE 

Figure 4.0-6 illustrates the request/acknowledge cycle for the non maskable interrupt. This signal is 
sampled at the same time as the interrupt line, but this line has priority over the normal interrupt and it can 
not be disabled under software control. Its usual function is to provide immediate response to important 
signals such as an impending power failure. The CPU response to a non maskable interrupt is similar to a 
normal memory read operation. The only difference being that the content of the data bus is ignored while 
the processor automatically stores the PC in the external stack and jumps to location 0066™. The service 
routine for the non maskable interrupt must begin at this location if this interrupt is used. 

HALT EXIT 

Whenever a software halt instruction is executed the CPU begins executing NOP's until an interrupt is 
received (either a non maskable or a maskable interrupt while the interrupt flip flop is enabled). The two 
interrupt lines are sampled with the rising clock edge during each T4 state as shown in figure 4.0-7. If a non 
maskable interrupt has been received or a maskable interrupt has been received and the interrupt enable 
flip-flop is set, then the halt state will be exited on the next rising clock edge. The following cycle will then 
be an interrupt acknowledge cycle corresponding to the type of interrupt that was received. If both are 
received at this time, then the non maskable one will be acknowledged since it has highest priority. The 
purpose of executing NOP instructions while in the* halt state is to keep the memory refresh signals active. 
Each cycle in the halt state is a normal Ml (fetch) cycle except that the data received from the memory is 
ignored and a NOP instruction is forced internally to the CPU. The halt acknowledge signal is active during 
this time to indicate that the processor is in the halt state. 
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5.0 Z-80 CPU INSTRUCTION SET 

The Z-80 CPU can execute 158 different instruction types including all 78 of the 8080A CPU. 
The instructions can be broken down into the following major groups: 

• Load and Exchange 

• Block Transfer and Search 

• Arithmetic and Logical 

• Rotate and Shift 

• Bit Manipulation (set, reset, test) 

• Jump, Call and Return 

• Input/Output 

• Basic CPU Control 

5.1 INTRODUCTION TO INSTRUCTION TYPES 

The load instructions move data internally between CPU registers or between CPU registers and exter- 
nal memory. All of these instructions must specify a source location from which the data is to be moved 
and a destination location. The source location is not altered by a load instruction. Examples of 
load group instructions include moves between any of the general purpose registers such as move the data 
to Register B from Register C. This group also includes load immediate to any CPU register or to any 
external memory location. Other types of load instructions allow transfer between CPU registers and 
memory locations. The exchange instructions can trade the contents of two registers. 

A unique set of block transfer instructions is provided in the Z-80. With a single instruction a 
block of memory of any size can be moved to any other location in memory. This set of block moves 
is extremely valuable when large strings of data must be processed. The Z-80 block search instructions 
are also valuable for this type of processing. With a single instruction, a block of external memory 
of any desired length can be searched for any 8-bit character. Once the character is found or the end of the 
block is reached, the instruction automatically terminates. Both the block transfer and the block search 
instructions can be interrupted during their execution so as to not occupy the CPU for long periods of time. 

The arithmetic and logical instructions operate on data stored in the accumulator and other 
general purpose CPU registers or external memory locations. The results of the operations are placed 
in the accumulator and the appropriate flags are set according to the result of the operation. An 
example of an arithmetic operation is adding the accumulator to the contents of an external memory 
location. The results of the addition are placed in the accumulator. This group also includes 16-bit 
addition and subtraction between 16-bit CPU registers. 

The rotate and shift group allows any register or any memory location to be rotated right or left 
with or without carry either arithmetic or logical. Also, a digit in the accumulator can be rotated right 
or left with two digits in any memory location. 

The bit manipulation instructions allow any bit in the accumulator, any general purpose register 
or any external memory location to be set, reset or tested with a single instruction. For example, 
the most significant bit of register H can be reset. This group is especially useful in control applications 
and for controlling software flags in general purpose programming. 

The jump, call and return instructions are used to transfer between various locations in the user's 
program. This group uses several different techniques for obtaining the new program counter address 
from specific external memory locations. A unique type of call is the restart instruction. This instruction 
actually contains the new address as a part of the 8-bit OP code. This is possible since only 8 separate 
addresses located in page zero of the external memory may be specified. Program jumps may also 
be achieved by loading register HL, IX or IY directly into the PC, thus allowing the jump address to 
be a complex function of the routine being executed. 
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The input/output group of instructions in the Z-80 allow for a wide range of transfers between 
external memory locations or the general purpose CPU registers, and the external I/O devices. In 
each case, the port number is provided on the lower 8 bits of the address bus during any I/O 
transaction. One instruction allows this port number to be specified by the second byte of the instruction 
while other Z-80 instructions allow it to be specified as the content of the C register. One major ad- 
vantage of using the C register as a pointer to the I/O device is that it allows different I/O ports to 
share common software driver routines. This is not possible when the address is part of the OP code 
if the routines are stored in ROM. Another feature of these input instructions is that they set the 
flag register automatically so that additional operations are not required to determine the state of 
the input data (for example its parity). The Z-80 CPU includes single instructions that can move 
blocks of data (up to 256 bytes) automatically to or from any I/O port directly to any memory location. 
In conjunction with the dual set of general purpose registers, these instructions provide for fast 
I/O block transfer rates. The value of this I/O instruction set is demonstrated by the fact that the 
Z-80 CPU can provide all required floppy disk formatting (i.e., the CPU provides the preamble, address, 
data and enables the CRC codes) on double density floppy disk drives on an interrupt driven basis. 

Finally, the basic CPU control instructions allow various options and modes. This group includes 
instructions such as setting or resetting the interrupt enable flip flop or setting the mode of interrupt 
response. 



5.2 ADDRESSING MODES 

Most of the Z-80 instructions operate on data stored in internal CPU registers, external memory 
or in the I/O ports. Addressing refers to how the address of this data is generated in each instruction. 
This section gives a brief summary of the types of addressing used in the Z-80 while subsequent sections 
detail the type of addressing available for each instruction group. 



Immediate. In this mode of addressing the byte following the OP code in memory contains the 
actual operand. 



*7 



OP Code 



Operand 



} 



one or 2 bytes 



l 



Examples of this type of instruction would be to load the accumulator with a constant, where the constant 
is the byte immediately following the OP code. 

Immediate Extended. This mode is merely an extension of immediate addressing in that the two 
bytes following the OP codes are the operand. 



OP code 



Operand 



Operand 



one or 2 bytes 
low order 
high order 



Examples of this type of instruction would be to load the HL register pair (16-bit register) with 
16 bits (2 bytes) of data. 
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Modified Page Zero Addressing. The Z-80 has a special single byte CALL instruction to any of 8 locations 
in page zero of memory. This instruction (which is referred to as a restart) sets the PC to an effective 
address in page zero. The value of this instruction is that it allows a single byte to specify a complete 
16-bit address where commonly called subroutines are located, thus saving memory space. 



OP Code 



one byte 
Effective address is (b 5 b 4 b 3 000) 2 



Relative Addressing. Relative addressing uses one byte of data following the OP code to specify a 

displacement from the existing program to which a program jump can occur. This displacement is 

a signed two's complement number that is added to the address of the OP code of the following instruction. 



OP Code 



Operand 



Jump relative (one byte OP code) 

8-bit two's complement displacement added to Address (A+2) 



The value of relative addressing is that it allows jumps to nearby locations while only requiring two 
bytes of memory space. For most programs, relative jumps are by far the most prevalent type of 
jump due to the proximity of related program segments. Thus, these instructions can significantly 
reduce memory space requirements. The signed displacement can range between +127 and -128 
from A+2. This allows for a total displacement of + 129 to -126 from the jump relative OP code address. 
Another major advantage is that it allows for relocatable code. 

Extended Addressing. Extended Addressing provides for two bytes (16 bits) of address to be included 
in the instruction. This data can be an address to which a program can jump or it can be an address 
where an operand is located. 



OP Code 



Low Order Address or Low order operand 



High Order Address or high order operand 



} 



one or two bytes 



Extended addressing is required for a program to jump from any location in memory to any other location, 
or load and store data in any memory location. 

When extended addressing is used to specify the source or destination address of an operand, 
the notation (nn) will be used to indicate the content of memory at nn, where nn is the 16-bit address 
specified in the instruction. This means that the two bytes of address nn are used as a pointer to a memory 
location. The use of the parentheses always means that the value enclosed within them is used as a 
pointer to a memory location. For example, (1200) refers to the contents of memory at location 1200. 



Indexed Addressing. In this type of addressing, the byte of data following the OP code contains 
a displacement which is added to one of the two index registers (the OP code specifies which index 
register is used) to form a pointer to memory. The contents of the index register are not altered by this 
operation. %- 



OP Code 



OP Code 



Displacement 



two byte OP code 



Operand added to index register to form a pointer to memory. 
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An example of an indexed instruction would be to load the contents of the memory location 
(Index Register + Displacement ) into the accumulator. The displacement is a signed two's complement 
number. Indexed addressing greatly simplifies programs using tables of data since the index register 
can point to the start of any table. Two index registers are provided since very often operations require 
two or more tables. Indexed addressing also allows for relocatable code. 

The two index registers in the Z-80 are referred to as IX and IY. To indicate indexed addressing the 
notation: 

(IX+d) or (lY+d) 

is used. Here d is the displacement specified after the OP code. The parentheses indicate that this 
value is used as a pointer to external memory. 

Register Addressing. Many of the Z-80 OP codes contain bits of information that specify which 

CPU register is to be used for an operation. An example of register addressing would be to load the 
data in register B into register C. 

Implied Addressing. Implied addressing refers to operations where the OP code automatically 

implies one or more CPU registers as containing the operands. An example is. the set of arithmetic 
operations where the accumulator is always implied to be the destination of the results. 

Register Indirect Addressing. This type of addressing specifies a 1 6-bit CPU register pair (such as HL) 
to be used as a pointer to any location in memory. This type of instruction is very powerful and 
it is used in a wide range of applications. 



I) 



OP Code ? one or two bytes 



An example of this type of instruction would be to load the accumulator with the data in the memory 
location pointed to by the HL register contents. Indexed addressing is actually a form of register indirect 
addressing except that a displacement is added with indexed addressing Register indirect addressing 
allows for very powerful but simple to implement memory accesses. The block move and search commands 
in the Z-80 are extensions of this type of addressing where automatic register incrementing, decrementing 
and comparing has been added. The notation for indicating register indirect addressing is to put 
parentheses around the name of the register that is to be used as the pointer. For example, the symbol 

(HL) 

specifies that the contents of the HL register are to be used as a pointer to a memory location. Often 
register indirect addressing is used to specify 1 6-bit operands. In this case, the register contents 
point to the lower order portion of the operand while the register contents are automatically incremented 
to obtain the upper portion of the operand. 

Bit Addressing. The Z-80 contains a large number of bit set, reset and test instructions. These 
instructions allow any memory location or CPU register to be specified for a bit operation through 
one of three previous addressing modes (register, register indirect and indexed) while three bits in the OP 
code specify which of the eight bits is to be manipulated. 



ADDRESSING MODE COMBINATIONS 

Many instructions include more than one operand (such as arithmetic instructions or loads). In 

these cases, two types of addressing may be employed. For example, load can use immediate addressing 
to specify the source and register indirect or indexed addressing to specify the destination. 
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5.3 INSTRUCTION OP CODES 

This section describes each of the Z-80 instructions and provides tables listing the OP codes for every 
instruction. In each of these tables the OP codes in shaded areas are identical to those offered in the 8080A 
CPU. Also shown is the assembly language mnemonic that is used for each instruction. All instruction OP 
codes are listed in hexadecimal notation. Single byte OP codes require two hex characters while double 
byte OP codes require four hex characters. The conversion from hex to binary is repeated here for 
convenience. 



lex 




Binary 




Decimal 





= 


0000 


= 





1 


= 


0001 


= 


1 


2 


= 


0010 


= 


2 


3 


= 


0011 


= 


3 


4 


= 


0100 


= 


4 


5 


= 


0101 


= 


5 


6 


= 


0110 


= 


6 


7 


= 


0111 


= 


7 



iex 




Binary 


] 


Decin 


8 


= 


1000 


= 


8 


9 


= 


1001 


= 


9 


A 


= 


1010 


= 


10 


B 


= 


1011 


= 


11 


C 


= 


1100 


= 


12 


D 


= 


1101 


= 


13 


E 


= 


1110 


= 


14 


F 


= 


mi 


= 


15 



Z-80 instruction mnemonics consist of an OP code and zero, one or two operands. Instructions in 
which the operand is implied have no operand. Instructions which have only one logical operand or those in 
which one operand is invariant (such as the Logical OR instruction) are represented by a one operand 
mnemonic. Instructions which may have two varying operands are represented by two operand mnemonics. 

LOAD AND EXCHANGE 

Table 5.3-1 defines the OP code for all of the 8-bit load instructions implemented in the Z-80 CPU. 
Also shown in this table is the type of addressing used for each instruction. The source of the data is found 
on the top horizontal row while the destination is specified by the left hand column. For example, load 
register C from register B uses the OP code 48H. In all of the tables the OP code is specified in hexadecimal 
notation and the 48H (=0100 1000 binary) code is fetched by the CPU from the external memory during 
Ml time, decoded and then the register transfer is automatically performed by the CPU. 

The assembly language mnemonic for this entire group is ID, followed by the destination followed 
by the source (LD DEST., SOURCE). Note that several combinations of addressing modes are possible. For 
example, the source may use register addressing and the destination may be register indirect; such as load 
the memory location pointed to by register HL with the contents of register D. The OP code for this 
operation would be 72. The mnemonic for this load instruction would be as follows: 

LD (HL), D 

The parentheses around the HL means that the contents of HL are used as a pointer to a memory location. 
In all Z-80 load instruction mnemonics the destination is always listed first, with the source following. The 
Z-80 assembly language has been defined for ease of programming. Every instruction is self documenting 
and programs written in Z-80 language are easy to maintain. 

Note in table 5.3-1 that some load OP codes that are available in the Z-80 use two bytes. This is an 
efficient method of memory utilization since 8, 16, 24 or 32 bit instructions are implemented in the Z-80. 
Thus often utilized instructions such as arithmetic or logical operations are only 8-bits which results in 
better memory utilization than is achieved with fixed instruction sizes such as 16-bits. 

All load instructions using indexed addressing for either the source or destination location 
actually use three bytes of memory with the third byte being the displacement d. For example a load 
register E with the operand pointed to by IX with an offset of +8 would be written: 

LDE,(IX+8) 
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The instruction sequence for this in memory would be: 



Address A 

A+1 
A+2 


DD 

5E 
08 



OP Code 



Displacement operand 



The two extended addressing instructions are also three byte instructions. For example the instruction to 
load the accumulator with the operand in memory location 6F32H would be written: 

LD A, (6F 32H) 

and its instruction sequence would be: 

OP Code 

low order address 

high order address 

Notice that the low order portion of the address is always the first operand. 



Address A 

A+1 

A+2 


3A 
32 
6F 



The load immediate instructions for the general purpose 8-bit registers are two-byte instructions. The 
instruction load register H with the value 36H would be written: 

LD H, 36H 

and its sequence would be: 



OP Code 
Operand 



A 

A+1 


26 
36 



Loading a memory location using indexed addressing for the destination and immediate addressing for the 
source requires four bytes. For example: 

LD(IX-15),21H 
would appear as: 



Address A 
A+1 

A+2 
A+3 


DD 

36 
Fl 
21 



OP Code 

displacement (-15 in 
signed two's complement) 

operand to load 



Notice that with any indexed addressing the displacement always follows directly after the OP code. 

Table 5.3-2 specifies the 16-bit load operations. This table is very similar to the previous one. Notice 
that the extended addressing capability covers all register pairs. Also notice that register indirect operations 
specifying the stack pointer are the PUSH and POP instructions. The mnemonic for these instructions is 
"PUSH" and "POP." These differ from other 16-bit loads in that the stack pointer is automatically decre- 
mented and incremented as each byte is pushed onto or popped from the stack respectively. For example 
the instruction: 
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PUSHAF 

is a single byte instruction with the OP code of F5H. When this instruction is executed the following 
sequence is generated: 

Decrement SP 

LD (SP), A 

Decrement SP 

LD (SP), F 

Thus the external stack now appears as follows: 







(SP) 


F 


(SP+1) 


A 
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• 







Top of stack 
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(DE) 


(IX + di 


(lY+di 


Inn) 
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ED 
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DD 
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06 
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4f 


48 


49 


4A 
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4C 


40 


4E 






DO 

4E 
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FD 
4E 
d 




OE 
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D 






57 


SO 


91 


52 


S3 


64 


55 


55 






DD 
56 
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FD 
56 
d 




16 
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E 






SF 


88 
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SA 


SB 


SC 


50 


SE 
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IE 
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H 
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60 


61 


62 


63 


64 


65 


66 
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FD 
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d 




26 
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68 
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60 
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8 BIT LOAD GROUP 

'LD' 

TABLE 5.3-1 
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Address A 


11 


A+l 


59 


A+2 


06 



The POP instruction is the exact reverse of a PUSH. Notice that all PUSH and POP instructions utilize a 
16-bit operand and the high order byte is always pushed first and popped last. That is a: 

PUSHBC is PUSH B then C 

PUSHDE is PUSH D then E 

PUSHHL is PUSH H then-L 

POP HL is POP LthenH 

The instruction using extended immediate addressing for the source obviously requires 2 bytes of data 
following the OP code. For example: 

LD DE, 0659H 

will be: 

OP Code 

Low order operand to register E 

High order operand to register D 

In all extended immediate or extended addressing modes, the low order byte always appears first after the 
OP code. 

Table 5.3-3 lists the 16-bit exchange instructions implemented in the Z-80. OP code 08H allows the 
programmer to switch between the two pairs of accumulator flag registers while D9H allows the pro- 
grammer to switch between the duplicate set of six general purpose registers. These OP codes are only one 
byte in length to absolutely minimize the time necessary to perform the exchange so that the duplicate 
banks can be used to effect very fast interrupt response times. 



BLOCK TRANSFER AND SEARCH 

Table 5.34 lists the extremely powerful block transfer instructions. All of these instructions operate 
with three registers. 

HL points to the source location. 
DE points to the destination location. 
BC is a byte counter. 

After the programmer has initialized these three registers, any of these four instructions may be used. The 
LDI (Load and Increment) instruction moves one byte from the location pointed to by HL to the location 
pointed to by DE. Register pairs HL and DE are then automatically incremented and are ready to point to 
the following locations. The byte counter (register pair BC) is also decremented at this time. This instruc- 
tion is valuable when blocks of data must be moved but other types of processing are required between each 
move. The LDIR (Load, increment and repeat) instruction is an extension of the LDI instruction. The same 
load and increment operation is repeated until the byte counter reaches the count of zero. Thus, this single 
instruction can move any block of data from one location to any other. 

Note that since 16-bit registers are used, the size of the block can be up to 64K bytes (IK = 1024) 
long and it can be moved from any location in memory to any other location. Furthermore the blocks can 
be overlapping since there are absolutely no constraints on the data that is used in the three register pairs. 

The LDD and LDDR instructions are very similar to the LDI and LDIR. The only difference is that 
register pairs HL and DE are decremented after every move so that a block transfer starts from the highest 
address of the designated block rather than the lowest. 
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'PUSH' AND 'POP' 
TABLE 5.3-2 





IMPLIED ADDRESSING 




af' 


BC', DE' & HL' 


HL 


IX 


IY 


IMPLIED 


AF 


08 










BC, 
DE 
& 
HL 




D9 








DE 






EB 






REG. 
INDIR. 


(SP) 






E3 


DD 

E3 


FD 

E3 



EXCHANGES 
'EX' AND 'EXX' 
TABLE 5.3-3 
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SOURCE 



DESTINATION 





REG. 
INDIR. 






(HL) 




REG. 
INDIR. 


(DE) 


ED 
AO 


'LDI'-Load(DE)-* — (HL) 
IncHL&DE, Dec BC 


ED 
BO 


'LDIR/- Load (DE)-* — (HL) 

Inc HL & DE, Dec BC, Repeat until BC = 


ED 
A8 


'LDD' - Load (DEM — (HL) 
DecHL& DE, Dec BC 


ED 
B8 


'LDDR' - Load (DEH« (HL) 

Dec HL & DE, Dec BC, Repeat until BC = 



Reg HL points to source 
Reg DE points to destination 
Reg BC is byte counter 



BLOCK TRANSFER GROUP 
TABLE 5.3-4 



Table 5.3-5 specifies the OP codes for the four block search instructions. The first, CPI (compare and 
increment) compares the data in the accumulator, with the contents of the memory location pointed to by 
register HL. The result of the compare is stored in one of the flag bits (see section 6.0 for a detailed expla- 
nation of the flag operations) and the HL register pair is then incremented and the byte counter (register 
pair BC) is decremented. 

The instruction CPIR is merely an extension of the CPI instruction in which the compare is repeated 
until either a match is found or the byte counter (register pair BC) becomes zero. Thus, this single instruc- 
tion can search the entire memory for any 8-bit character. 

The CPD (Compare and Decrement) and CPDR (Compare, Decrement and Repeat) are similar 
instructions, their only difference being that they decrement HL after every compare so that they search 
the memory in the opposite direction. (The search is started at the highest location In the memory block). 

It should be emphasized again that these block transfer and compare instructions are extremely 
powerful in string manipulation applications. 

ARITHMETIC AND LOGICAL 

Table 5.3-6 lists all of the 8-bit arithmetic operations that can be performed with the accumulator, 
also listed are the increment (INC) and decrement (DEC) instructions. In all of these instructions, except 
INC and DEC, the specified 8-bit operation is performed between the data in the accumulator and the 
source data specified in the table. The result of the operation is placed in the accumulator with the excep- 
tion of compare (CP) that leaves the accumulator unaffected. All of these operations affect the flag 
register as a result of the specified operation. (Section 6.0 provides all of the details on how the flags are 
affected by any instruction type). INC and DEC instructions specify a register or a memory location as 
both source and destination of the result. When the source operand is addressed using the index registers 
the displacement must follow directly. With immediate addressing the actual operand will follow directly. 
For example the instruction: 

AND07H 



would appear as: 



Address A 

A+1 


E6 

07 



OP Code 
Operand 
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SEARCH 
LOCATION 



REG. 
(NDIR. 




(HL) 




ED 
A1 


'CPI' 

Inc HL, Dec BC 


ED 
B1 


'CPIRMncHL, Dec BC 

repeat until BC = or find match 


ED 
A9 


'CPD'DecHL&BC 


ED 
B9 


'CPDR'DecHL&BC 

Repeat until BC = or find match 



HL points to location in memory 

to be compared with accumulator 

contents 
BC is byte counter 

BLOCK SEARCH GROUP 
TABLE 5.3-5 

Assuming that the accumulator contained the value F3H the result of 03H would be placed in the 
accumulator: 

Ace before operation 1111 001 1 = F3H 

Operand 0000 0111 = 07H 

Result to Ace 0000 001 1 = 03H 

The Add instruction (ADD) performs a binary add between the data in the source location and the 
data in the accumulator. The subtract (SUB) does a binary subtraction. When the add with carry is specified 
(ADC) or the subtract with carry (SBC), then the carry flag is also added or subtracted respectively. The 
flags and decimal adjust instruction (DAA) in the Z-80 (fully described in section 6.0) allow arithmetic 
operations for: 

multiprecision packed BCD numbers 

multiprecision signed or unsigned binary numbers 

multiprecision two's complement signed numbers 

Other instructions in this group are logical and (AND), logical or (OR), exclusive or (XOR) and compare (CP). 

There are five general purpose arithmetic instructions that operate on the accumulator or carry flag. 
These five are listed in table 5.3-7. The decimal adjust instruction can adjust for subtraction as well as add- 
ition, thus making BCD arithmetic operations simple. Note that to allow for this operation the flag N is used. 
This flag is set if the last arithmetic operation was a subtract. The negate accumulator (NEG) instruction 
forms the two's complement of the number in the accumulator. Finally notice that a reset carry instruction 
is not included in the Z-80 since this operation can be easily achieved through other instructions such as a 
logical AND of the accumulator with itself. 

Table 5.3-8 lists all of the 16-bit arithmetic operations between 16-bit registers. There are five groups 
of instructions including add with carry and subtract with carry. ADC and SBC affect all of the flags. These 
two groups simplify address calculation operations or other 16-bit arithmetic operations. 
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SOURCE 















REG. 














REGISTER ADDRESSING 




INDIR. 


INDEXED 


IMMED. 




A 


B 


C 


D 


E 


H 


L 


(HL) 


(IX+d) 


(lY+d) 


n 




















DD 


FD 




'ADD' 


87 


80 


81 


82 


83 


84 


85 


86 


86 

d 


86 

d 


C6 
n 




















DD 


FD 




ADD w CARRY 


8F 


88 


89 


8A 


8B 


8C 


8D 


8E 


8E 


8E 


CE 


'ADC 


















d 


d 


n 




















DD 


FD 




SUBTRACT 


97 


90 


91 


92 


93 


94 


95 


96 


96 


96 


D6 


'SUB' 


















d 


d 


n 




















DD 


FD 




SUB w CARRY 


9F 


98 


99 


9A 


9B 


9C 


9D 


9E 


9E 


9E 


DE 


'SBC 


















d 


d 


n 




















DD 


FD 




'AND' 


A7 


AO 


A1 


A2 


A3 


A4 


A5 


A6 


A6 

d 


A6 

d 


E6 
n 




















DD 


FD 




'XOR' 


AF 


A8 


A9 


AA 


AB 


AC 


AD 


AE 


AE 

d 


AE 

d 


EE 
n 




















DD 


FD 




'OR' 


B7 


BO 


B1 


B2 


B3 


B4 


B5 


66 


B6 

d 


B6 

d 


F6 

n 




















DD 


FD 




COMPARE 


BF 


B8 


B9 


BA 


BB 


BC 


BD 


BE 


BE 


BE 


FE 


'CP* 


















d 


d 


n 




















DD 


FD 




INCREMENT 


3C 


04 


OC 


14 


1C 


24 


2C 


34 


34 


34 




'INC 


















d 


d 






















DD 


FD 




DECREMENT 


3D 


05 


OD 


15 


1D 


25 


2D 


35 


35 


35 




'DEC 


















d 


d 





8 BIT ARITHMETIC AND LOGIC 
TABLE 5.3-6 



Decimal Adjust Ace, 'DAA' 


27 
2F 


Complement Ace, 'CPL' 


Negate Ace, 'NEG' 
(2's complement) 


ED 
44 


Complement Carry Flag, 'CCF' 


3F 
37 


Set Carry Flag, 'SCF' 



GENERAL PURPOSE AF OPERATIONS 
TABLE 5.3-7 
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SOURCE 



DESTINATION 







BC 


DE 


HL 


SP 


IX 


IY 


•ADD' 


HL 


09 


19 


29 


39 






IX 


DD 
09 


DD 
19 




DD 
39 


DD 
29 




IY 


FD 
09 


FD 
19 




FD 
39 




FD 
29 


ADD WITH CARRY AND 
SET FLAGS 'ADC 


HL 


ED 
4A 


ED 
5A 


ED 
6A 


ED 
7A 






SUB WITH CARRY AND 
SET FLAGS 'SBC 


HL 


ED 
42 


ED 
52 


ED 
62 


ED 
72 






INCREMENT 'INC' 


03 


13 


23 


33 


DD 
23 


FD 
23 


DECREMENT 'DEC 


OB 


1B 


2B 


3B 


DD 

I 2B 


FD 
2B 



16 BIT ARITHMETIC 
TABLE 5.3-8 



ROTATE AND SHIFT 



A major capability of the Z-80 is its ability to rotate or shift data in the accumulator, any general pur- 
pose register, or any memory location. All of the rotate and shift OP codes are shown in table 5.3-9. Also 
included in the Z-80 are arithmetic and logical shift operations. These operations are useful in an extremely 
wide range of applications including integer multiplication and division. Two BCD digit rotate instructions 
(RRD and RLD) allow a digit in the accumulator to be rotated with the two digits in a memory location 
pointed to by register pair HL. (See figure 5.3-9). These instructions allow for efficient BCD arithmetic. 

BIT MANIPULATION 

The ability to set, reset and test individual bits in a register or memory location is needed in almost 
every program. These bits may be flags in a general purpose software routine, indications of external con- 
trol conditions or data packed into memory locations to make memory utilization more efficient. 

The Z-80 has the ability to set, reset or test any bit in the accumulator, any general purpose register 
or any memory location with a single instruction. Table 5.3-10 lists the 240 instructions that are available 
for this purpose. Register addressing can specify the accumulator or any general purpose register on which 
the operation is to be performed. Register indirect and indexed addressing are available to operate on 
external memory locations. Bit test operations set the zero flag (Z) if the tested bit is a zero. (Refer to 
section 6.0 for further explanation of flag operation). 

JUMP, CALL AND RETURN 

Figure 5.3-1 1 lists all of the jump, call and return instructions implemented in the Z-80 CPU. A jump 
is a branch in a program where the program counter is loaded with the 1 6-bit value as specified by one of the 
three available addressing modes (Immediate Extended, Relative or Register Indirect). Notice that the jump 
group has several different conditions that can be specified to be met before the jump will be made. If 
these conditions are not met, the program merely continues with the next sequential instruction. The 
conditions are all dependent on the data in the flag register. (Refer to section 6.0 for details on the flag 
register). The immediate extended addressing is used to jump to any location in the memory. This in- 
struction requires three bytes (two to specify the 16-bit address) with the low order address byte first 
followed by the high order address byte. 
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Source and Destination 



TYPE 
OF 

ROTATE 
OR 

SHIFT 





A 


B 


C 


D 


E 


H 


L 


<HU 


(IX +d) 


(lY + d) 


"RLC 


CB 
07 


CB 
00 


CB 
01 


CB 
02 


CB 
03 


CB 
04 


CB 
05 


CB 
06 


DD 
CB 
d 
06 


FD 
CB 
d 
06 


*RRC 


CB 
OF 


CB 
08 


CB 
09 


CB 

0A 


CB 
OB 


CB 
OC 


CB 
OD 


CB 

OE 


DD 
CB 
d 
OE 


FD 
CB 
d 
OE 


'RL' 


CB 
17 


CB 
10 


CB 
11 


CB 
12 


CB 

13 


CB 
14 


CB 

15 


CB 
16 


DD 
CB 
d 
16 


FD 
CB 
d 
16 


'RR' 


CB 
1F 


CB 
18 


CB 
19 


CB 
1A 


CB 
IB 


CB 
1C 


CB 

ID 


CB 
1E 


DD 
CB 
d 

1E 


FD 
CB 
d 
1E 


'SLA' 


CB 
27 


CB 
20 


CB 
21 


CB 
22 


CB 
23 


CB 
24 


CB 

25 


CB 
26 


DD 
CB 
d 
26 


FD 
CB 
d 
26 


"SRA' 


CB 
2F 


CB 
28 


CB 
29 


CB 
2A 


CB 
2B 


CB 
2C 


CB 
2D 


CB 
2E 


DD 
CB 
d 

2E 


FD 
CB 
d 
2E 


*SRL' 


CB 
3F 


CB 
38 


CB 
39 


CB 
3A 


CB 
3B 


CB 
3C 


CB 
3D 


CB 

3E 


DD 
CB 
d 
3E 


FD 
CB 
d 

3E 


'RLD' 
















ED 
6F 






'RRD' 
















ED 
67 








[cy]**— {**7 — b o~j — -J 






Rotate 

Right Circular 



Rotate 
Right 



0— [ 



|*-0 



^e 



HzTpC 



Shift 

Right Logical 



[ b 3- b 0| 
ACC f 



b 7- b 4 b 3- b D <HL> 



H 



Rotate Digit 
Right 



ROTATES AND SHIFTS 
TABLE 5.3-9 



For example an unconditional Jump to memory location 3E32H would be: 



Address A 
A+l 

A+2 


C3 

32 
3E 



OP Code 

Low order address 

High order address 



The relative jump instruction uses only two bytes, the second byte is a signed two's complement dis- 
placement from the existing PC. This displacement can be in the range of +129 to -126 and is measured 
from the address of the instruction OP code. 

Three types of register indirect jumps are also included. These instructions are implemented by loading 
the register pair HL or one of the index registers IX or IY directly into the PC. This capability allows for 
program jumps to be a function of previous calculations. 

A call is a special form of a jump where the address of the byte following the call instruction is 
pushed onto the stack before the jump is made. A return instruction is the reverse of a call because the 
data on the top of the stack is popped directly into the PC to form a jump address. The call and return 
instructions allow for simple subroutine and interrupt handling. Two special return instructions have been 
included in the Z-80 family of components. The return from interrupt instruction (RETI) and the return 
from non maskable interrupt (RETN) are treated in the CPU as an unconditional return identical to the OP 
code C9H. The difference is that (RETI) can be used at the end of an interrupt routine and all Z-80 peripheral 
chips will recognize the execution of this instruction for proper control of nested priority interrupt handling. 
This instruction coupled with the Z-80 peripheral devices implementation simplifies the normal return from 
nested interrupt. Without this feature the following software sequence would be necessary to inform the 
interrupting device that the interrupt routine is completed: 
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REG. 








REGISTER ADDRESSING 






INDIR. 


INDEXED 




A 


B 


C 


D 


E 


H 


L 


(HL) 


(IX+d! 


(lY+d). 


BIT 










































DD 


FD 







CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






47 


40 


41 


42 


43 


44 


45 


46 


d 
46 


d 
46 




















DD 


FD 




1 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






4F 


48 


49 


4A 


4B 


4C 


4D 


4E 


d 

4E 


d 
4E 




















DD 


FD 




2 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






57 


50 


51 


52 


53 


54 


55 


56 


d 

56 


d 
56 




















DD 


FD 




3 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






5F 


58 


59 


5A 


5B 


5C 


5D 


5E 


d 


d 


TEST 
•BIT- 




















5E 


5E 




















DD 


FD 




4 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






67 


60 


61 


62 


63 


64 


65 


66 


d 
66 


d 
66 




















DD 


FD 




5 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






6F 


68 


69 


6A 


6B 


6C 


6D 


6E 


d 

6E 


d 
6E 




















DD 


FD 




6 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






77 


70 


71 


72 


73 


74 


75 


76 


d 
76 


d 
76 




















DD 


FD 




7 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






7F 


78 


79 


7A 


7B 


7C 


7D 


7E 


d 
7E 


d 
7E 






















DD 


FD 







CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






87 


80 


81 


82 


83 


84 


85 


86 


d 
86 


d 
86 




















DD 


FD 




1 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






8F 


88 


89 


8A 


8B 


8C 


8D 


8E 


d 
BE 


d 
8E 




















DD 


FD 




2 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






97 


90 


91 


92 


93 


94 


95 


96 


d 
96 


d 
96 




















00 


FD 




3 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


RESET 

BIT 

'RES' 




9F 


98 


99 


9A 


9B 


9C 


90 


9E 


d 
9E 


d 

9E 


4 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


DD 
CB 


FD 
CB 






A7 


A0 


A1 


A2 


A3 


A4 


A5 


A6 


d 
A6 


d 
A6 




















DD 


FD 




5 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






AF 


AS 


A9 


AA 


AB 


AC 


AD 


AE 


d 
AE 


d 

AE 




















OD 


FD 




6 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






B7 


BO 


B1 


B2 


B3 


B4 


B5 


B6 


d 
B6 


d 
B6 




















DD 


FD 




7 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






BF 


B8 


B9 


BA 


BB 


BC 


BD 


BE 


d 

BE 


d 
BE 






















DD 


FD 







CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






C7 


CO 


C1 


C2 


C3 


C4 


C5 


C6 


C6 


C6 




















OD 


FD 




1 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






CF 


C8 


C9 


CA 


CB 


CC 


CD 


CE 


d 
CE 


d 
CE 




















DD 


FD 




2 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






D7 


DO 


01 


D2 


D3 


D4 


D5 


D8 


d 

D6 


d 
D6 




















DD 


FD 




3 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


SET 
BIT 




DF 


D8 


D9 


DA 


DB 


DC 


OD 


DE 


d 

DE 


DE 




















DD 


FD 




4 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






E7 


EO 


E1 


E2 


E3 


E4 


E5 


E6 


d 
E6 


E6 




















DD 


FD 




5 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






EF 


E8 


E9 


EA 


EB 


EC 


ED 


EE 


d 

EE 


EE 




















DD 


FD 




6 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






F7 


FO 


F1 


F2 


F3 


F4 


F5 


F6 


F6 


F6 




















DD 


FD 




7 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 


CB 






FF 


F8 


F9 


FA 


FB 


FC 


FD 


FE 


d 

FE 


d 

FE 



BIT MANIPULATION GROUP 
TABLE 5.3-10 
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Disable Interrupt 

LDA, n 
OUT n, A 

Enable Interrupt 

Return 



prevent interrupt before 
routine is exited. 

notify peripheral that service 
routine is complete 



This seven byte sequence can be replaced with the one byte EI instruction and the two byte RETI instruction 
in the Z80. This is important since interrupt service time often must be minimized. 

To facilitate program loop control the instruction DJNZ e can be used advantageously. This two byte 
relative jump instruction decrements the B register and the jump occurs if the B register has not been decre-' 
mented to zero. The relative displacement is expressed as a signed two's complement number. A simple ex- 
ample of its use might be; 



Address 
N, N+l 

N + 2 to N + 9 

N+10 3 N+11 
N+12 



Instruction 

LDB, 7 

(Perform a sequence 
of instructions) 

DJNZ -8 

(Next Instruction) 



Comments 

; set B register to count of 7 

; loop to be performed 7 times 
; to jump from N + 12 to N + 2 



CONDITION 









UN- 
COND. 


CARRY 


NON 
CARRY 


ZERO 


NON 
ZERO 


PARITY 
EVEN 


PARITY 
ODD 


SIGN 
NEG 


SIGN 
POS 


REG 

B#0 


JUMP *JP' 


IMMED. 
EXT. 


nn 


--C3 

n 
n 


DA 

n 

n 


D2 

n 
n 


CA 

n 
n 


C2 

n 
n 


EA 

n 

n 


E2 

n 
n 


FA 

n 

n 


F2 

n 
n 




JUMP MR' 


RELATIVE 


PC+e 


18 
e-2 


38 
e-2 


30 
e-2 


28 
e-2 


20 
e-2 












JUMP 'JP' 


REG. 
INDIR. 


(HL) 


E9 




















JUMP 'JP' 


(IX) 


DD 
E9 




















JUMP 'JP' 


(IY> 


FD 
E9 




















'CALL* 


IMMED. 
EXT. 


nn 


CD 

n 
n 


DC 

n 
n 


W 

n 
n 


cc 

n 
n 


C4 
n 

n 


EC 

n 
n 


n 
n 


PC 

n 

n 


F4 
ft 

ft 




DECREMENT B, 
JUMP IF NON 
ZERO 'DJNZ' 


RELATIVE 


PC+e 




















10 
e-2 


RETURN 

•RET' 


REGISTER 
INDIR. 


(SP) 
(SP+1) 


C9 


D8 


DO 


C8 


CO 


E8 


E0 


F8 


F0 




RETURN FROM 
INT 'RETI' 


REG. 
INDIR. 


(SP) 
(SP+1) 


ED 
4D 




















RETURN FROM 
NON MASKABLE 
INT'RETN' 


REG. 
INDIR. 


(SP) 
(SP+1) 


ED 
45 





















FLAGS HAVE MORE 
THAN ONE PURPOSE. 
REFER TO SECTION 
6.0 FOR DETAILS 



JUMP, CALL and RETURN GROUP 
TABLE 5.3-11 
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''Table 5.3-12 lists the eight OP codes for the restart instruction. This instruction is a single byte call to any 
of the eight addresses listed. The simple mnemonic for these eight calls is also shown. The value of this in- 
struction is that frequently used routines can be called with this instruction to miriimize memory usage. 







OP 
CODE 


c 

A 
L 
L 

A 
D 
D 
R 

E 
S 
S 


oooo H 


C7 


0008 H 


CF 


ooto H 


D7 


0018 H 


DF 


0020 H 


E7 


0028 H 


EF 


0030 H 


F7 


0038 H 


FF 



'RST 0' 



'RST 8' 



'RST 16' 



'RST 24' 



'RST 32' 



'RST 40' 



'RST 48' 



'RST 56' 



RESTART GROUP 
TABLE 5.3-12 



INPUT/OUTPUT 

The Z-80 has an extensive set of Input and Output instructions as shown in table 5.3-13 and table 
.5.3-14. The addressing of the input or output device can be either absolute or register indirect, using the C 
register. Notice that in the register indirect addressing mode data can be transferred between the I/O devices 
and any of the internal registers. In addition eight block transfer instructions have been implemented. These 
instructions are similar to the memory block transfers except that they use register pair HL for a pointer to 
the memory source (output commands) or destination (input commands) while register B is used as a byte 
counter. Register C holds the address of the port for which the input or output command is desired. Since 
register 3 is eight bits in length, the I/O block transfer command handles up to 256 bytes. 

In the instructions IN A, n and OUT n 5 A the I/O device address n appears in the lower half of the add- 
ress bus (Ag-A7) while the accumulator content is transferred in the upper half of the address bus. In all reg- 
ister indirect input output instructions, including block I/O transfers the co'ntent of register C is transferred 
to the lower half of the address bus (device address) while the content of register B is transferred to the 
upper half of the address bus. 
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SOURCE 
PORT ADDRESS 



INPUT 
DESTINATION 





IMMED. 


REG. 
INDIR. 




(n) 


(C) 


INPUT 'IN' 


R 
E 
G 

A 

D 

D 

R 

E 

S 

S 

1 

N 

G 


A 


DB 


ED 
78 


B 




ED 
40 


C 




ED 
48 


D 




ED 
50 


E 




ED 
58 


H 




ED 
60 


L 




ED 
68 


*INI'- INPUT & 
Inc HL, Dec B 


REG, 
INDIR 


(HL) 




ED 
A2 


'INIR*-INP, IncHL, 
Dec B, REPEAT IF B#0 




ED 
B2 


'IND'-INPUT& 
Dec HL, DecB 




ED 
AA 


'INDR'- INPUT, Dec HL, 
Dec B, REPEAT IF B#0 




ED 
BA 



BLOCK INPUT 
COMMANDS 



INPUT GROUP 
TABLE 5.3-13 

CPU CONTROL GROUP 

The final table, table 5 .3-15 illustrates the six general purpose CPU control instructions. The NOP is a do- 
nothing instructioa The HALT instruction suspends CPU operation until a subsequent interrupt is received, 
while the DI and EI are used to lock out and enable interrupts. The three interrupt mode commands set the 
CPU into any of the three available interrupt response modes as follows. If mode zero is set the interrupting 
device can insert any instruction on the data bus and allow the CPU to execute it. Mode 1 is a simplified 
mode where the CPU automatically executes a restart (RST) to location 0038H so that no external hardware 
is required. (The old PC content is pushed onto the stack). Mode 2 is the most powerful in that it allows for 
an indirect call to any location in memory. With this mode the CPU forms a 16-bit memory address where 
the upper 8-bits are the content of register I and the lower 8-bits are supplied by the interrupting device. 
This address points to the first of two sequential bytes in a table where the address of the service routine is 
located. The CPU automatically obtains the starting address and performs a CALL to this address. 



Address of interrupt 
service routine 



■ Pointer to Interrupt table. Reg. 
I is upper address, 
Peripheral supplies lower address 
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SOURCE 









REGISTER 


REG. 
IND. 




A 


B 


C 


D 


E 


H 


L 


(HL) 


'OUT' 


IMMED. 


(n) 


D3 

n 
















REG. 
IND. 


(C) 


ED 
79 


ED 
41 


ED 
49 


ED 
51 


ED 
59 


ED 
61 


ED 
69 




'OUTI'- OUTPUT 
Inc HL, Dec b 


REG. 
IND. 


(C) 
















ED 
A3 


'OTIR* - OUTPUT, IncHL, 
Dec B, REPEAT IF B=5*0 


REG. 
IND. 


(C) 
















ED 
B3 


'OUTD* - OUTPUT 
DecHL& B 


REG. 
IND. 


(C) 
















ED 
AB 


'OTDR' - OUTPUT, Dec HL 
&B, REPEAT IF B=£0 


REG. 
IND. 


(C) 
















ED 
BB 



y 



— v^ 
PORT 

DESTINATION 
ADDRESS 



BLOCK 
> OUTPUT 
COMMANDS 



OUTPUT GROUP 
TABLE 5.3-14 



'NOP' 


00 


'HALT' 


76 


DISABLE INT '(DO* 


F3 


ENABLE INT '(El)' 


FB 


SET INT MODE 
'IMO* 


ED 
46 


SET INT MODE 1 
'IM1* 


ED 
56 


SET INT MODE 2 
'IMZ 


ED 
5E 



8080A MODE 



CALL TO LOCATION 0038 H 



INDIRECT CALL USING REGISTER 
I AND 8 BITS FROM INTERRUPTING 
DEVICE AS A POINTER. 



MISCELLANEOUS CPU CONTROL 
TABLE 5.3-15 
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-BLANK- 



-38- 



6.0 FLAGS 

Each of the two Z-80 CPU Flag registers contains six bits of information which are set or reset by 
various CPU operations. Four of these bits are testable; that is, they are used as conditions for jump, call or 
return instructions. For example a jump may be desired only if a specific bit in the flag register is set. The 
four testable flag bits are: 

1) Carry Flag (C) — This flag is the carry from the highest order bit of the accumulator. For example, the 
carry flag will be set during an add instruction where a carry from the highest bit of the accumulator 
is generated. This flag is also set if a borrow is generated during a subtraction instruction. The shift 
and rotate instructions also affect this bit. 

2) Zero Flag (Z) — This flag is set if the result of the operation loaded a zero into the accumulator. Other- 
wise it is reset. 

3) Sign Flag (S) - This flag is intended to be used with signed numbers and it is set if the result 
of the operation was negative. Since bit 7 (MSB) represents the sign of the number (A negative 
number has a 1 in bit 7), this flag stores the state of bit 7 in the accumulator. 

4) Parity /Overflow Flag (P/V) — This dual purpose flag indicates the parity of the result in the accumulator 
when logical operations are performed (such as AND A, B) and it represents overflow when signed 
two's complement arithmetic operations are performed. The Z-80 overflow flag indicates that the 
two's complement number in the accumulator is in error since it has exceeded the maximum pos- 
sible (+127) or is less than the minimum possible (-128) number than can be represented in two's 
complement notation. For example consider adding: 

+ 120 = 0111 1000 
+ 105= 0110 1001 



C= 1110 0001 = -95 (wrong) Overflow has occured 

Here the result is incorrect. Overflow has occurred and yet there is no carry to indicate an error. 
For this case the overflow flag would be set. Also consider the addition of two negative numbers: 

-5 = 1111 1011 
-16= 11110000 



C = 1 1110 1011 = -21 correct 

Notice that the answer is correct but the carry is set so that this flag can not be used as an over- 
flow indicator. In this case the overflow would not be set. 

For logical operations (AND, OR, XOR) this flag is set if the parity of the result is even and it is 
reset if it is odd. 

There are also two non-testable bits in the flag register. Both of these are used for BCD arithmetic. They are: 

1) Half carry (H) - This is the BCD carry or borrow result from the least significant four bits of operation. 
When using the DAA (Decimal Adjust Instruction) this flag is used to correct the result of a 
previous packed decimal add or subtract. 

2) Subtract Flag (N) - Since the algorithm for correcting BCD operations is different for addition or 

subtraction, this flag is used to specify what type of instruction was executed last so that the 
DAA operation will be correct for either addition or subtraction. 

The Flag register can be accessed by the programmer and its format is as follows: 



X means flag is indeterminate. 



S 


z 


X 


H 


X 


P/V 


N 


C 
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Table 6.0-1 lists how each flag bit is affected by various CPU instructions. In this table a '•' indicates 
that the instruction does not change the flag, an '3C means that the flag goes to an indeterminate state, a '0' 
m;ans that it is reset, a T means that it is set and the symbol '$' indicates that it is set or reset according to 
the previous discussion. Note that any instruction not appearing in this table does not affect any of the flags. 

Table 6.0-1 includes a few special cases that must be described for clarity. Notice that the block search 
instruction sets the Z flag if the last compare operation indicated a match between the source and the 
accumulator data. Also, the parity flag is set if the byte counter (register pair BC) is not equal to zero. This 
same use of the parity flag is made with the block move instructions. Another special case is during block 
input or output instructions, here the Z flag is used to indicate the state of register B which is used as a byte 
counter. Notice that when the I/O block transfer is complete, the zero flag will be reset to a zero (i.e. B=0) 
while in the case of a block move command the parity flag is reset when the operation is complete. A final 
case is when the refresh or I register is loaded into the accumulator, the interrupt enable flip flop is loaded 
into the parity flag so that the complete state of the CPU can be saved at any time. 
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Instruction 



ADD A, s; ADC A,s 

SUB s; SBC A, s, CP s, NEG 

ANDs 
OR s; XOR s 
INCs 
DECm 
ADD DD, ss 
ADC HL, ss 
SBC HL, ss 

RLA; RLCA, RRA, RRCA 

RL m; RLC m; RR m; RRC m 

SLA m; SRA m; SRL m 

RLD, RRD 

DAA 

CPL 

SCF 

CCF 

IN r, (C) 

INI;IND;OUTI;OUTD 

INIR; INDR; OTIR; OTDR 

LDI,LDD 

LDIR, LDDR 

CPI,CPIR,CPD,CPDR 



LD A, I; LD A, R 

BIT b, s 

NEG 



c 


z 


N 


s 


N 


H 


t 


* 


V 


X 





t 


X 


$ 


V 


X 


1 


X 





X 


p 


X 





1 





X 


p 


t 








• 


X 


V 


X 





i 


• 


X 


V 


X 


1 


X 


X 


• 


• 


• 





X 


X 


X 


V 


X 





X 


X 


X 


V 


X 


1 


X 


X 


• 


• 


• 








X 


* 


p 


X 








• 


* 


p 


t 








* 


X 


p 


X 


• 


X 


• 


• 


• 


• 


1 


1 


1 


• 


• 


• 








X 


• 


• 


• 





X 


• 


X 


p 


* 








• 


t 


X 


X 


1 


X 


• 


1 


X 


X 


1 


X 


• 


X 


$ 


X 








• 


X 





X 








• 


X 


t 


$ 


1 


X 


• 


X 


[FI 


'X 








• 


X 


X 


X 





1 


$ 


X 


V 


t 


1 


X 



Comments 

8-bit add or add with carry 

8-bit subtract, subtract with carry, compare and 

negate accumulator 
Logical operations 
And set's different flags 
8-bit increment 
8-bit decrement 
16-bit add 

16-bit add with carry 
16-bit subtract with carry 
Rotate accumulator 
Rotate and shift location m 

Rotate digit left and right 

Decimal adjust accumulator 

Complement accumulator 

Set carry 

Complement carry 

Input register indirect 

Block input and output 

Z = if B # otherwise Z = 1 

Block transfer instructions 

P/V = 1 if BC # 0, otherwise P/V = 

Block search instructions 

Z = 1 if A = (HL), otherwise Z = 

P/V = 1 if BC =£ 0, otherwise P/V = 
The content of the interrupt enable flip-flop (IFF) 

is copied into the P/V flag 
The state of bit b of location s is copied into the Z flag 
Negate accumulator 



The following notation is used in this table: 

Symbol Operation 

C Carry/link flag. C=l if the operation produced a carry from the MSB of the operand or result. 

Z Zero flag. Z=l if the result of the operation is zero. 

S Sign flag. S=l if the MSB of the result is one. 

P/V Parity or overflow flag. Parity (P) and overflow (V) share the same fkg. Logical operations affect this flag 

with the parity of the result while arithmetic operations affect this flag with the overflow of the result. If P/V 
holds parity, P/V=l if the result of the operation is even, P/V=0 if result is odd. If P/V holds overflow, P/V=l 
if the result of the operation produced an overflow. 

H Half-carry flag. H=l if the add or subtract operation produced a carry into or borrow from into bit 4 of the accumulator. 

N Add/Subtract flag. N=l if the previous operation was a subtract 

H and N flags are used in conjunction with the decimal adjust instruction (DAA) to properly correct the re- 
sult into packed BCD format following addition or subtraction using operands with packed BCD format. 

X The flag is affected according to the result of the operation. 

• The flag is unchanged by the operation. 

The flag is reset by the operation. 

1 The flag is set by the operation. 
X The flag is a "don't care." 

V P/V flag affected according to the overflow result of the operation. 

P P/V flag affected according to the parity result of the operation. 

r Any one of the CPU registers A, B, C, D, E, H, L. 

s Any 8-bit location for all the addressing modes allowed for the particular instruction. . 

ss Any 16-bit location for all the addressing modes allowed for that instruction. 

ii Any one of the two index registers IX or IY. 

R Refresh counter, 

n 8-bit value in range <2), 255> 

m 16-bit value in range <0, 65535> 

m Any 8-bit location for all the addressing modes allowed for the particular instruction. 



SUMMARY OF FLAG OPERATION 
TABLE 6.0-1 
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7.0 SUMMARY OF OP CODES AND EXECUTION TIMES 

The following section gives a summary of the £-80 instructions set. The instructions are logically arranged 
into groups as shown on tables 7.0-1 through 7.0-11. Each table shows the assembly language mnemonic 
OP code, the actual OP code, the symbolic operation, the content of the flag register following the execu- 
tion of each instruction, the number of bytes required for each instruction as well as the number of memory 
cycles and the total number of T states (external clock periods) required for the fetching and execution of 
each instruction. Care has been taken to make each table self-explanatory without requiring any cross refer- 
ence with the test or other tables. 
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Symbolic 
Operation 






Fte 


gs 






OP-Code 


No. 

of 

Bytes 


No. 

ofM 

Cycles 


No. 
ofT 
Cycles 


Comm 




Mnemonic 


C 


zp/ys 


N 


H 


76 543 210 


ents 


LDr, r* 


r<-r' 


• 


• 


• 


• 


• 


• 


01 r r* 


1 


1 


4 


r, r* 


Reg. 


LDr, n 


r<-n 


• 


• 


• 


• 


• 


• 


00 r 110 
+- n -+ 


2 


2 


7 


000 
001 


B 
C 


LD r, (HL) 


r-(HL) 


• 


• 


• 


• 


• 


• 


01 r 110 


1 


2 


7 


010 


D 


LD r, (IX+d) 


r - (IX+d) 


• 


• 


• 


• 


•<- 


» 


11 011 101 
01 r no 

- d -* 


3 


5 


19 


on 

100 
101 


E 
H 
L 


LD r, (IY+d) 


r *- (IY+d) 


• 


• 


• 


• 


• 


• 


11 111 101 
01 r 110 
- d -> 


3 


5 


19 


in 


A 


LD (HL), r 


(HL)«-r 


• 


• 


• 


• 


• 


• 


01 110 r 


1 


2 


7 






LD (IX+d), r 


(IX+d) - r 


• 


• 


• 


• 


• 


• 


11 011 101 
01 110 r 

«_ d - 


3 


5 


19 






LD (IY+d), r 


(IY+d) <- r 


• 


• 


• 


• 


• 


• 


11 111 101 
01 110 r 

- d - 


3 


5 


19 






LD (HL), n 


(HL) - n 


• 


• 


• 


• 


• 


• 


00 110 110 
«- n -* 


2 


3 


10 






LD (IX+d), n 


(IX+d) - n 


• 


• 


• 


• 


• 


• 


11 011 101 
00 110 110 

«_ d - 
+- n -+ 


4 


5 


19 






LD (IY+d), n 


(IY+d)*-n 


• 


• 


• 


• 


• 


• 


11 111 101 
00 110 110 

«- d - 


4 


5 


19 






LD A, (BC) 


A «- (BC) 


• 


• 


• 


• 


• 


• 


00 001 010 


1 


2 


7 






LD A, (DE) 


A *- (DE) 


• 


• 


• 


• 


• 


• 


00 011 010 


1 


2 


7 






LD A, (nn) 


A «- (nn) 


• 


• 


• 


• 


• 


• 


00 111 010 
«- n -* 

*- n -+ 


3 


4 


13 






LD (BC), A 


(BC) «- A 


• 


• 


• 


• 


• 


• 


00 000 010 


1 


2 


7 






LD (DE), A 


(DE) - A 


• 


• 


• 


• 


• 


• 


00 010 010 


1 


2 


7 






LD (nn), A 


(nn) <- A 


• 


• 


• 


• 


• 


• 


00 110 010 

<- n -+ 
<- n -+ 


3 


4 


13 






LD A, I 


A<-I 


• 


t 


IFF* 








11 101 101 
01 010 111 


2 


2 


9 






LD A, R 


A*-R 


• 


% 


IFF* 








11 101 101 


2 


2 


9 






















01 011 111 












LDI.A 


I«-A 


• 


• 


• 


• 


• 


• 


11 101 101 
01 000 111 


2 


2 


9 






LDR, A 


R-A 


• 


• 


• 


• 


• 


• 


11 101 101 
01 001 111 


2 


2 


9 







Notes: r, f means any of the registers A, B, C, D, E, H, L 

IFF the content of the interrupt enable flip-flop (IFF) is copied into the P/V flag 

Flag Notation: e = flag not affected, = flag reset, 1 = flag set, X = flag is unknown, 
t = flag is affected according to the result of the operation. 



8-BIT LOAD GROUP 
TABLE 7.0-1 
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Symbolic 
Operation 



Flags 



Z V 



Op-Code 



No. 

or 

Bytes 



No. 
ofM 
Cycles 



No. 
ofT 
States 



Comments 



LD IX, nn 

LD IY, nn 

LD HL, (nn) 
LD dd, (nn) 

LD IX, (nn) 

LD IY, (nn) 

LD (nn), HL 
LD (nn), dd 

LD (nn), IX 

LD (nn), IY 

LD SP, HL 
LDSP.IX 

LD SP, IY 

PUSHqq 

PUSH IX 

PUSHIY 

POPqq 

POP IX 

POPIY 



H-(nn+l) 
L - (nn) 

ddo «-(nn+l) 
dd, «- (nn) 



IX H -(nn+l) 
IX, -(nn) 



IY H -(nn+l) 



'H 

IY, -(nn) 



(nn+l)—H 
(nn)-L 

(nn+l)*-ddjj 
(nn) «- dd. 



(nn+D-IXjj 
(nil) - IX L 



(nn+l)-IY H 
(nn)-IY L 



SP-HL 
SP-IX 



(SP-2)«-qq L 

(SP-l)-qq H 

(SP-2)i-IX L 

(SP-1)*-IX H 

(SP-2)-IY L 

(SP-1) - IY H 

qq H *-(SP+l) 

qq L -(SP) 

IX H -(SP+1) 

IX L - (SP) 

IY H -(SP+1) 

IY L -(SP) 



«- n -* 

*- n -» 

11 Oil 101 

00 100 001 

•*- n -» 

«- n -* 

11 111 101 

00 100 001 

«- n -* 

«- n -* 

00 101 010 

— n -* 
•*- n -» 
11 101 101 

01 ddl 011 
«- n -* 
*- n -» 
11 011 101 
00 101 010 
«- n -♦ 

— n -* 
11 111 101 
00 101 010 
<- n -* 

— n -» 

00 100 010 
«- n -* 
«- n -♦ 
11 101 101 

01 ddO 011 
*- n -» 
<- n -► 
11 011 101 
00 100 010 
*- n -* 
«- n -» 
11 111 101 
00 100 010 



11 111 001 

11 011 101 

11 111 001 

11 111 101 

11 111 001 

11 qqO 101 

11 011 101 
11 100 101 
11 111 101 
11 100 101 
11 qqO 001 

11 011 101 
11 100 001 
11 111 101 
11 100 001 



dd Paii 

00 BC 

01 DE 

10 HL 

11 SP 



qq Pate 

00 BC 

01 DE 

10 HL 

11 AF 



Notes: ddisany of the register pairs BC, DE, HL, SP 
qq is any of the register pairs AF, BC, DE, HL 

(PAIR) H , (PAIR), refer to high order and low order eight bits of the register pair respectively. 
E.g. BC L = C, AF H = A 

Flag Notation: • = flag not affected, = flag reset, 1 = flag set, X = flag is unknown, 
t flag is affected according to the result of the operation. 



16-BIT LOAD GROUP 
TABLE 7.0-2 
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Mnemonic 



Symbolic 
Operation 



Flags 



Op -Code 



76 543 210 



No. 

of 

Bytes 



No. 

ofM 

Cycles 



No. 
ofT 
States 



Comments 



EX DE, HL 

EX AF, AF' 
EXX 

EX (SP), HL 
EX (SP), IX 
EX (SP), IY 

LD1 



LDIR 



LDD 



LDDR 



CP1 



CPIR 



CPD 



CPDR 



DE»HL 

AF ~ AF' 

'BC\ /BC*\ 

DEHDE'J 

KHU \HL7 

H«(SP+l) 

L « (SP) 

IX H «(SP+1) 

IX L **(SP) 

IY„«(SP+1) 



H 



IY, 



(SP) 



CD 



@® 



t t 



® 



©CD 



11 101 on 

00 001 000 

11 011 001 

11 100 on 

11 011 101 

11 100 011 

11 111 101 

11 100 011 

11 101 101 

10 100 000 



11 101 101 
10 110 000 



1 t 



II 101 101 
10 101 000 



II 101 101 2 
10 11 1 000 2 



11 101 101 
10 100 001 



11 101 101 

io no ooi 



11 101 101 
10 101 001 



11 101 101 
10 111 001 



4 
4 

19 
23 
23 

16 



16 



16 



16 



Register bank and 
auxiliary register 
bank exchange 



(DE)«-(HL) 
DE - DE+ 1 
HL-HL+1 
BC - BC- 1 

(DE)-(HL) 
DE*-DE+1 
HL- HL+1 
BC-BC-1 
Repeat until 
BC = 

(DE)-(HL) 
DE-DE-1 
HL-HL-1 
BC-BC-I 

(DE)-(HL) 
DE-DE-1 
HL-HL-1 
BC-BC-1 
Repeat until 
BC =0 

A - (HL) 
HL-HL+1 
BC - BC- 1 

A - (HL) 
HL-HL+1 
BC-BC-1 
Repeat until 
A = (HL) or 
BC = 

A-(HL) 

HL-HL-1 

BC-BC-1 

A-(HL) 
HL-HL-1 
BC-BC-1 
Repeat until 
A = (HL) or 
BC = 



Notes: ® P/V flag is if the result of BC-1 = 0, otherwise P/V = 1 
© Z flag is 1 if A = (HL), otherwise Z = 0. 

Flag Notation: • = flag not affected, = flag reset. 1 = flag set, X = flag is unknown, 
t = Hag is affected according to the result of the operation. 



EXCHANGE GROUP AND BLOCK TRANSFER AND SEARCH GROUP 

TABLE 7.0-3 



Load (HL) into 
(DE), increment the 
pointers and 
decrement the byte 
counter (BC) 

IfBC*0 
IfBC = 



IfBC*0 
IfBC=0 



IfBC^Oand A # (HL) 
IfBC = 0orA = (HL) 



IfBC#0and A * (HL) 
IfBC = 0orA = (HL) 
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Flags 






Op-Code 


No. 


No. 


No. 












7 














Symbolic 














of 


ofM 


ofT 




Mnemonic 


Operation 


C 


z 


V 


s 


N 


H 


76 543 210 


Bytes 


Cycles 


States 


Comments 


ADDA,r 


A — A + r 


X 


X 


V 


X 





X 


10[000l r 


1 


1 


4 


r Reg. 


ADDA,n 


A<- A + n 


t 


X 


V 


X 





X 


11 loool 110 

•>- n -► 


2 


2 


7 


000 B 

001 C 
010 D 


ADD A, (HL) 


A *- A + (HL) 


X 


X 


V 


X 





X 


lofoool 110 


1 


2 


7 


011 E 


ADD A, (IX+d 


A*-A + (IX+d) 


X 


X 


V 


X 





X 


11 011 101 

lofoool 110 

- d -* 


3 


5 


19 


100 H 

101 L 

111 A 


ADDA,(IY+d 


A«-A+(IY+d) 


X 


X 


V 


t 





X 


11 111 101 

10 loool 110 

- d 


3 


5 


19 




ADCA,s 


A - A + s + CY 


X 


X 


V 


X 





X 


fooH 








s is any of r, n, 


SUBs 


A*- A-s 


X 


X 


V 


X 


1 


X 


foTol 








(HL), (IX+d), 
(IY+d) as shown lb 


SBC A, s 


A*- A-s-CY 


X 


X 


V 


X 


1 


X 


roTn 








ADD instruction 


ANDs 


A- A A s 





X 


p 


X 





1 


[Tool 










ORs 


A«-A V s 





X 


p 


X 








fnol 








The indicated bits 


XORs 


A i- A e s 





X 


p 


X 








mm 








replace the 000 in 
the ADD set above 


CPs 


A-s 


X 


X 


V 


X 


1 


X 


run 










INCr 


r-r+ 1 


• 


X 


V 


X 





X 


00 r 1 1 001 


1 


1 


4 




INC (HL) 


(HL)-(HL)+1 


• 


X 


V 


X 





X 


00 no [tool 


1 


3 


11 




INC (IX+d) 


(IX+d) - 
(IX+d)+l 


• 


X 


V 


X 





X 


11 011 101 
00 1 1 [ 1 00 1 

d 
11 111 101 


3 


6 


23 




INC(IY+d) 


(IY+d)«- 


• 


X 


V 


X 





X 


3 


6 


23 






(IY+d)+ 1 














oo "no [Tool 

- d 

iron 










DECm 


m<-m-l 


• 


} 


V 


X 


1 


X 








m is any of r, (HL) 
(IX+d), (IY+d) as 



Notes: 



shown for INC. 
Same format and 
states as INC. 
Replace 100 with 
101 in OP code. 

The V symbol in the P/V flag column indicates that the P.'V flag contains the overflow of the result of the 
operation Similarly the P symbol indicates parity. V = 1 means overflow, V = means not overflow. P = 1 
means parity of the result is even, P = means parity of the result is odd. 



Flag Notation: • = flag not affected, = flag reset, i = flag set, X = flag is unknown, 
X = flag is affected according to the result of the operation. 



8-BIT ARITHMETIC AND LOGICAL GROUP 
TABLE 7.0-4 
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Symbolic 
Operation 






Flags 






Op-Code 


No. 

of 

Bytes 


No. 

ofM 

Cycles 


No. 
ofT 
States 




Mnemonic 


C 


z 


\ 


s 


N 


H 


76 543 210 


Comments 


DAA 


Converts ace. 
content into 
packed BCD 
foEowing add 
or subtract 
with packed 
BCD operands 


t 


t 


P 


t 


• 


t 


00 100 111 


1 


1 


4 


Decimal adjust 
accumulator 


CPL 
NEG 


A*-A 
A-O-A 


• 


• 


• 
V 


• 


1 

1 


1 

t 


00 101 111 

11 101 101 

01 000 100 


1 

2 


1 
2 


4 
8 


Complement 
accumulator 
(one's complement) 
Negate ace. (two's 
complement) 


CCF 
SCF 


CY-CY 
CY-1 


t 
1 


• 
• 


• 
• 


• 
• 






X 



00 111 111 
00 110 111 


1 
1 


1 
1 


4 
4 


Complement carry 

flag 

Set carry flag 


NOP 


No operation 














00 000 000 


1 


1 


4 




HALT 


CPU halted 


• 


• 


• 


• 


• 


• 


01 110 110 


1 


1 


4 




DI 


IFF*-0 














11 110 011 


1 


1 


4 




EI 


IFF-1 


• 


• 


• 


• 


• 


• 


11 111 011 


1 


1 


4 




IMO 


Set interrupt 
mode 














11 101 101 
01 000 110 


2 


2 


8 




tMl 


Set interrupt 
mode 1 














11 101 101 
01 010 110 


2 


2 


8 




IM2 


Set interrupt 
mode 2 


• 


• 


• 


• 


• 


• 


11 101 101 
01 011 110 


2 


2 


8 





Notes: IFF indicates the interrupt enable flip-flop 
CY indicates the carry flip-flop . 

Flag Notation: • = flag not affected, = flag reset, 1 = flag set, X = flag is unknown, 
t = flag is affected according to the result of the operation. 



GENERAL PURPOSE ARITHMETIC AND CPU CONTROL GROUPS 

TABLE 7.0-5 
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Symbolic 
Operation 






Flags 






Op-Code 


No. 

of 

Bytes 


No. 

ofM 

Cycles 


No. 
ofT 
States 


Comm 




Mnemonic 


C 


Z 


% 


s 


N 


H 


76 543 210 


ents 


ADD HL, ss 


HL«-HL+ss 


t 


• 


• 


• 





X 


00 ssl 001 


1 


3 


11 


ss 

00 


Reg. 
BC 


ADC HL, ss 


HL-HL+ss+CY 


t 


t 


V 


t 





X 


11 101 101 
01 ssl 010 


2 


4 


15 


01 
10 

11 


DE 
HL 
SP 


SBC HL, ss 


HL-HL-ss-CY 


t 


t 


V 


t 


1 


X 


11 101 101 
01 ssO 010 


2 


4 


15 






ADD IX, pp 


IX - IX + pp 


t 


• 


• 


m 





X 


11 011 101 
00 ppl 001 


2 


4 


15 


pp 

00 
01 
10 

11 


Reg. 

BC 
DE 

IX 
SP 


ADDIY.rx 


IY-IY+ rr 


t 


• 


• 


• 





X 


11 111 101 
00 rrl 001 


2 


4 


15 


rr 

00 
01 
10 

11 


Reg. 

BC 
DE 
IY 
SP 


INCss 


ss «- ss + 1 


• 










• 


00 ssO Oil 


1 


1 


6 






INC IX 


IX-IX + 1 


• 










• 


11 Oil 101 
00 100 Oil 


2 


2 


10 






INCIY 


IY - IY + 1 


• 










• 


11 111 101 
00 100 Oil 


2 


2 


10 






DEC ss 


ss «- ss - 1 


• 










• 


00 ssl Oil 


1 


1 


6 






DEC IX 


IX - IX - 1 


• 










• 


11 Oil 101 
00 101 Oil 


2 


2 


10 






DECIY 


IY - IY - 1 


• 










• 


11 111 101 
00 101 on 


2 


2 


10 







Notes: ss is any of the register pairs BC, DE, HL, SP 
pp is any of the register pairs BC, DE, IX, SP 
rr is any of the register pairs BC, DE, IY, SP. 

Flag Notation: • = flag not affected, = flag reset, I = flag set, X = flag is unknown, 
t = flag is affected according to the result of the operation. 



16-BIT ARITHMETIC GROUP 
TABLE 7.0-6 
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Mnemonic 



Symbolic 
Operation 



Flags 



Op-Code 



76 543 210 



No. 

of 

Bytes 



No. 

ofM 

Cycles 



No. 
ofT 
States 



Comments 



RLCA 

RLA 

RRCA 

RRA 

RLCr 
RLC (HL) 
RLC (IX+d) 

RLC (IY+d) 

RLm 

RRCm 

RRm 

SLAm 

SRAm 

SRLm 

RLD 

RRD 



|cy|— L |7 -m — o} »-i 

A 
|cv[— — — J7 ■♦— p|— -< 



L j 7 — o^ -Lf^i 

A 



EzHMl^EZH 



t, (HL), (IX+d), <IY+d) 



I — [cy| < — 17 ■* o) *J 

m s r, (HL), (IX+d), (IY+d) 

i— l? ■ — »• o| -1«4cy| 

mSr,(HL), (IX+d), (IY+d) 

L> J7 »• o | » [ cy| — I 

m3r.(HL),(IX+d),(lY+d) 



E3* — I 7 ■* — o] — -0 
msr,(HL), (IX+d), (IY+d) 



fS 



o|— — (cy| 



J s r, (HL), (IX+d), (IY+d) 



0-» ^7 »■ o| — — JCY| 

m3r,(HL),(IX+d),(IY+d) 



Ap 4h ol It 4h 0|(HL) 



r ~ ~>r~t 

A |7 4|3 p| 1 7 4|3 d| <HL) 



X P 



00 000 111 



00 010 111 



00 001 111 



00 011 111 



11 001 011 
OO lOOOl r 
11 001 011 

oo fbool iio 

11 011 101 
11 001 011 

- d - 
oo loooh io 

11 111 101 

ii ooi on 



ooloooliio 



looTI 



fTool 


rTon 


LUD 


11 101 101 


01 101 111 


11 101 101 


01 100 111 



1 



1 



Flag Notation: • = flag not affepted, = flag reset, 1 = flag set, X = flag is unknown, 
t - flag is affected according to the result of the operation. 



ROTATE AND SHIFT GROUP 
TABLE 7.0-7 



23 



18 



18 



Rotate left circular 
accumulator 



Rotate left 
accumulator 



Rotate right circular 
accumulator 



Rotate right 
accumulator 



Rotate left circular 
register r 



000 
001 
010 
011 
100 
101 
111 



Reg. 
B 
C 
D 

E 
H 
L 
A 



Instruction format and 
states are as shown 
for RLC,m. To form 
new OP-code replace 
iQOiof RLC ,m with 
shown code 



Rotate digit left and 
right between the 
accumulator 
and location (HL). 
The content of the 
upper half of the 
accumulator is 
unaffected 
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Mnemonic 



Symbolic 
Operation 



Flags 



Op-Code 



76 543 210 



No. 

of 

Bytes 



No. 

ofM 

Cycles 



No. 
ofT 
States 



Comments 



BITb.r 
BIT b, (HL) 
BIT b, (IX+d) 

BIT b, (IY+d) 



z*-T b 
z-Ihl^ 

Z*-(IX+d). 



z«- 



(IY+d^ 



SET b, r 
SET b, (HL) 
SET b, (IX+d) 

SET b, (IY+d) 
RES b,m 



(HL) U - 1 



(IX+d) b - 1 



(IY+d). - 1 



s^O 

m=r,(HL), 
(IX+d), 
(IY+d) 



11 001 Oil 
01 b r 
11 001 011 
01 b 110 
11 011 101 
11 001 011 
- d - 
01 b 110 
11 111 101 
11 001 011 
«- d - 
01 b 110 



11 001 011 
ED b r 
11 001 Oil 

[Til b no 

11 Oil 101 
11 001 Oil 

- d - 

OH b no 

11 111 101 

11 001 on 

<- d - 

im b 110 



8 

12 

20 

20 



15 
23 



23 



Notes: The notation s. indicates bit b (0 to 7) oi location s. 

Flag Notation: • = flag not affected, = flag reset, 1 = flag set, X = flag is unknown, 
t = flag is affected according to the result of the operation. 



BIT SET, RESET AND TEST GROUP 
TABLE 7.0-8 



T 


Reg. 


000 


B 


001 


C 


010 


D 


on 


E 


100 


H 


101 


L 


111 


A 



b 


Bit Tested 


000 





001 


1 


010 


2 


on 


3 


100 


4 


101 


5 


110 


6 


111 


7 



To form new OP- 
code replace [FT] 
of SET b,m with 
HCH . Flags and time 
states for SET 
instruction 
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Mnemonic 



Symbolic 
Operation 



Op-Code 



76 543 210 



No. 

of 

Bytes 



No. 

ofM 

Cycles 


No. 
ofT 
States 


3 


10 


3 


10 


3 


12 


2 


7 


3 


12 


2 


7 


3 


12 


2 


7 


3 


12 


2 


7 


3 


12 


1 


4 


2 


8 


2 


8 


2 


8 


3 


13 



Comments 



JPnn 
JP cc, nn 

JRe 
JRC.e 

JR NC, e 
JRZ.e 

JR NZ, e 

JP (HL) 
JP(IX) 
JP (IY) 

DJNZ,e 



11 000 011 



11 cc 010 



PC-nn 



If condition cc 
is true PC «-nn, 
otherwise 
continue 



PC*-PC+e 

IfC = 0, 
continue 

IfC=l, 
PC^PC+e 

IfC=l, 
continue 

If C = 0, 
PC-PC + e 

If Z = 
continue 

IfZ= 1, 
PC - PC + e 

If Z= 1, 
continue 

IfZ = 0, 
PC - PC + e 

PC.-HL 



PC<-IX 
PC-IY 



B^B-1 
If B = 0, 
continue 

If B * 0, 
PC-PC + e 



Notes: e represents the extension in the relative addressing mode. 

e is a signed two's complement number in the range <-126, 129> 

e-2 in the op-code provides an effective address of pc +e as PC is 
incremented by 2 prior to the addition of e. 

Flag Notation: • = flag not affected, = flag reset, 1 = flag set, X = flag is unknown, 
t = flag is affected according to the result of the operation. 



00 011 000 


2 


- e-2 - 




00 111 000 


2 


- e-2 - 






2 


00 110 000 


2 


- e _2 - 






2 


00 101 000 


2 


<- e-2 -* 






2 


00 100 000 


2 


- e-2 - 






2 


11 101 001 


1 


11 011 101 


2 


11 101 001 




11 111 101 


2 


11 101 001 




00 010 000 


2 


- e-2 - 





cc 


Condition 


000 


NZnon zero 


001 


Z zero 


010 


NCnon carry 


011 


C carry 


100 


PO parity odd 


101 


PE parity even 


110 


P sign positive 


111 


M sign negative 



If condition not met 

If condition is met 
If condition not met 

If condition is met 

If condition not met 

If condition is met 

If condition not mc 

If condition met 



lfB = 



IF B # 



JUMP GROUP 
TABLE 7.0-9 



52 



Mnemonic 



Symbolic 
Operation 



Op-Code 



76 543 210 



No. 

of 

Bytes 



No. 

ofM 

Cycles 



No. 
ofT 
States 



Comments 



CALL nn 



CALL cc, nn 



RET 



RETcc 



RETI 
RETN 
RSTp 



(SP-1)-PC H 
(SP-2)-PC L 
PC-nn 

If condition 
cc is false 
continue, 
otherwise 
same as 
CALL nn 

PC L *-(SP) 
PC H -(SP+1) 



If condition 
cc is false 
continue, 
otherwise 
same as 
RET 



Return from 
interrupt 

Return from 
non maskable 
interrupt 
(SP-lh-PC H 

(SP-2)*4>C L 

pc h -o 
pc l -p 



11 001 101 

«- n -* 

*- n -* 

11 cc 100 

+- n -*■ 



11 001 001 



11 cc 000 



11 101 101 
01 001 101 
11 101 101 
01 000 101 

11 t 111 



17 

10 
17 

10 

5 
11 

14 
14 
11 



Flag Notation: • = flag not affected, = flag reset, 1 = flag set, X = flag is unknown 
t = flag is affected according to the result of the operation. 



CALL AND RETURN GROUP 
TABLE 7.0-10 



If ccis false 
If cc is true 



If cc is false 



If ccis true 



cc 


Condition 


000 


NZ 


non zero 


001 


Z 


zero 


010 


NC 


non carry 


011 


C 


carry 


100 


PO 


parity odd 


101 


PE 


parity even 


110 


P 


sign positive 


111 


M 


sign negative 



t 


P 


000 


00H 


001 


08H 


010 


10H 


011 


18H 


100 


20H 


101 


28H 


110 


30H 


111 


38H 
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Symbolic 
Operation 






Flags 






Opcode 


No. 

of 

Bytes 


No. 

ofM 

Cycles 


No. 
ofT 
States 




Mnemonic 


C 


z 


V 


s 


N 


H 


76 543 210 


Comments 


IN A, (n) 


A-(n) 














11 Oil Oil 

*- n -* 


2 


3 


11 


n to Aq ~ A- 
Acc to A„ ~ A. - 


IN r, (C) 


r-(C) 
if r = 110 only 
the flags will 
be affected 


• 


t 


P 


t 





X 


11 101 101 
01 r 000 


2 


3 


12 


C to A Q ~ A ? 
BtoA g ~A 15 


INI 


(HL)-(C) 

B-B-l 

HL-HL+1 


• 


t 


X 


X 


1 


X 


11 101 101 
10 100 010 


2 


4 


16 


C to A Q ~ A ? 
BtoA 8 ~A 15 


INIR 


(HL) - (C) 
B-B-l 
HL - HL + 1 
Repeat until 
B = 


• 


i 
® 


X 


X 


1 


X 


11 101 101 
10 110 010 


2 
2 


5 
(If B # 0) 

4 
(If B = 0) 


21 
16 


C to A Q ~ A ? 
BtoA g ~A 15 


IND 


(HL) «- (C) 

B-B-l 

HL-HL-1 


• 


t 


X 


X 


1 


X 


11 101 101 
10 101 010 


2 


4 


16 


C to A„ ~ A ? 
BtoA g ~A 15 


INDR 


(HL) - (C) 
B-B-l 
HL-HL-1 
Repeat until 
B = 


• 


i 


X 


X 


1 


X 


11 101 101 
10 111 010 


2 
2 


5 
(IfB*0) 

4 
(If B = 0) 


21 
16 


C to A Q ~ A 
BtoA 8 ~A, 5 


OUT (n), A 


(n)-A 














11 010 011 

* — n — > 


2 


3 


11 


n to A„ ~ A_ 
Ace to A g ~ A 15 


OUT (C), r 


(Q-r 




® 










11 101 101 
01 r 001 


2 


3 


12 


C to A„ ~ A_ 
BtoA 8 ~A 15 


OUTI 


(C)-(HL) 
B-B- 1 
HL - HL + 1 


• 


t 


X 


X 


1 


X 


11 101 101 
10 100 011 


2 


4 


16 


C to A„ ~ A_ 
BtoA g ~A I5 


OTIR 


(C) - (HL) 

B-B-l 

HL - HL + 1 

Repeat until 
B = 


• 


i 
® 


X 


X 


1 


X 


11 101 101 
10 110 011 


2 
2 


5 
(If B * 0) 

4 
(If B = 0) 


21 
16 


C to A.. ~ A_ 
BtoA 8 ~A 15 


OUTD 


(C)-(HL) 
B-B- 1 
HL<-HL- 1 


• 


t 


X 


X 


1 


X 


11 101 101 
10 101 011 


2 


4 


16 


C to A.. ~ A_ 
BtoA g ~A 15 


OTDR 


(C) - (HL) 
B-B- 1 
HL-HL-1 
Repeat until 
B = 


• 


i 


X 


X 


1 


X 


11 101 101 
10 111 on 


2 
2 


5 
(If B # 0) 

4 
(IfB = 0) 


21 
16 


C to A„ ~ A_ 
BtoA 8 ~A 15 



Notes: (I) If the result of B - 1 is zero the Z flag is set, otherwise it is reset • 

Flag Notation: • = flag not affected, = flag reset, 1 = flag set, X = flag is unknown, 
t = flag is affected according to the result of the operation. 



INPUT AND OUTPUT GROUP 
TABLE 7.0-11 
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8.0 INTERRUPT RESPONSE 

The purpose of an interrupt is to allow peripheral devices to suspend CPU operation in an orderly 
manner and force the CPU to start a peripheral service routine. Usually this service routine is involved with 
the exchange of data, or status and control information, between the CPU and the peripheral. Once the 
service routine is completed, the CPU returns to the operation from which it was interrupted. 

INTERRUPT ENABLE - DISABLE 

The Z80 CPU has two interrupt inputs, a software maskable interrupt and a non maskable interrupt. 
The non maskable interrupt (NMI) can not be disabled by the programmer and it will be accepted when- 
ever a peripheral device requests it. This interrupt is generally reserved, for very important functions that 
must be serviced whenever they occur, such as an impending power failure. The maskable interrupt (INT) 
can be selectively enabled or disabled by the programmer. This allows the programmer to disable the inter- 
rupt during periods where his program has timing constraints that do not allow it to be interrupted. In the 
Z80 CPU there is an enable flip flop (called IFF) that is set or reset by the programmer using the Enable 
Interrupt (EI) and Disable Interrupt (DI) instructions. When the IFF is reset, an interrupt can not be 
accepted by the CPU. 

Actually, for purposes that will be subsequently explained, there are two enable flip flops, called IFF, 
and IFF2. 



IFFj 



IFF 2 



Actually disables interrupts Temporary storage location 

from being accepted. for IFF, . 

The state of IFFj is used to actually inhibit interrupts while IFF2 is used as a temporary storage location 
for IFFj. The purpose of storing the IFF} will be subsequently explained. 

A reset to the CPU will force both IFFj and IFF2 to the reset state so that interrupts are disabled. 
They can then be enabled by an EI instruction at any time by the programmer. When an EI instruction is 
executed, any pending interrupt request will not be accepted until after the instruction following EI has 
been executed. This single instruction delay is necessary for cases when the following instruction is a return 
instruction and interrupts must not be allowed until the return has been completed. The EI instruction sets 
both IFF1 and IFF2 to the enable state. When an interrupt is accepted by the CPU, both IFFj and IFF2 
are automatically reset, inhibiting further interrupts until the programmer wishes to issue a new EI instruc- 
tion. Note that for all of the previous cases, IFF} and IFF2 are always equal. 

The purpose of IFF2 is to save the status of IFF 1 when a non maskable interrupt occurs. When a non 
maskable interrupt is accepted, IFF} is reset to prevent further interrupts until reenabled by the pro- 
grammer. Thus, after a non maskable interrupt has been accepted, maskable interrupts are disabled but the 
previous state of IFF 1 has been saved so that the complete state of the CPU just prior to the non maskable 
interrupt can be restored at any time. When a Load Register A with Register I (LD A, I) instruction or a 
Load Register A with Register R (LD A, R) instruction is executed, the state of IFF2 is copied into the 
parity flag where it can be tested or stored. 

A second method of restoring the status of IFFj is thru the execution of a Return From Non 
Maskable Interrupt (RETN) instruction. Since this instruction indicates that the non maskable interrupt 
service routine is complete, the contents of IFF2 are now copied back into IFFj, so that the status of IFFj 
just prior to the acceptance of the non maskable interrupt will be restored automatically. 
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Figure 8.0-1 is a summary of the effect of different instructions on the two enable flip flops. 



Action 


IFFj 


CPU Reset 





DI 





EI 


1 


LDA,I 


• 


LDA,R 


• 


Accept NMI 





RETN 


IFF 2 



IFF2 -^Parity flag 
IFF2 -*• Parity flag 

IFF 2 ->IFF 1 



"•" indicates no change 

FIGURE 8.0-1 
INTERRUPT ENABLE/DISABLE FLIP FLOPS 



CPU RESPONSE 

Non Maskable 

A nonmaskable interrupt will be accepted at all times by the CPU. When this occurs, the CPU ignores 
the next instruction that it fetches and instead does a restart to location 0066H, Thus, it behaves exactly as 
if it had received a restart instruction but, it is to a location that is not one of the 8 software restart loca- 
tions. A restart is merely a call to a specific address in page of memory. 

Maskable 

The CPU can be programmed to respond to the maskable interrupt in any one of three possible 
modes. 

ModeO 

This mode is identical to the 8080A interrupt response mode. With this mode, the interrupting device 
can place any instruction on the data bus and the CPU will execute it. Thus, the interrupting device pro- 
vides the next instruction to be executed instead of the memory. Often this will be a restart instruction 
since the interrupting device only need supply a single byte instruction. Alternatively, any other instruction 
such as a 3 byte call to any location in memory could be executed. 

The number of clock cycles necessary to execute this instruction is 2 more than the normal number for the 
instruction. This occurs since the CPU automatically adds 2 wait states to an interrupt response cycle to 
allow sufficient time to implement an external daisy chain for priority control. Section 5.0 illustrates the 
detailed timing for an interrupt response. After the application of RESET the CPU will automatically enter 
interrupt Mode 0. 

Mode 1 

When this mode has been selected by the programmer, the CPU will respond to an interrupt by 
executing a restart to location 0038H. Thus the response is identical to that for a non maskable interrupt 
except that the call location is 0038H instead of 0066H. Another difference is that the number of cycles 
required to complete the restart instruction is 2 more than normal due to the two added wait states. 
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Mode 2 

This mode is the most powerful interrupt response mode. With a single 8 bit byte from the user an 
indirect call can be made to any memory location. 

With this mode the programmer maintains a table of 1 6 bit starting addresses for every interrupt 
service routine. This table may be located anywhere in memory. When an interrupt is accepted, a 16 bit 
pointer must be formed to obtain the desired interrupt service routine starting address from the table. 
The upper 8 bits of this pointer is formed from the contents of the I register. The I register must have been 
previously loaded with the desired value by the programmer, i.e. LD I, A. Note that a CPU reset clears the I 
register so that it is initialized to zero. The lower eight bits of the pointer must be supplied by the interrupt- 
ing device. Actually, only 7 bits are required from the interrupting device as the least significant bit must be 
a zero. This is required since the pointer is used to get two adjacent bytes to form a complete 16 bit service 
routine starting address and the addresses must always start in even locations. 



Interrupt 

Service 

Routine 

Starting 

Address 

Table 



low order 



high order 



} 



desired starting address 
pointed to by: 



I REG 
CONTENTS 


7 BITS FROM 
PERIPHERAL 






The first byte in the table is the least significant (low order) portion of the address. The programmer must 
obviously fill this table in with the desired addresses before any interrupts are to be accepted. 

Note that this table can be changed at any time by the programmer (if it is stored in Read/Write 
Memory) to allow different peripherals to be serviced by different service routines. 

Once the interrupting devices supplies the lower portion of the pointer, the CPU automatically pushes 
the program counter onto the stack, obtains the starting address from the table and does a jump to this 
address. This mode of response requires 19 clock periods to complete (7 to fetch the lower 8 bits from the 
interrupting device, 6 to save the program counter, and 6 to obtain the jump address.) 

Note that the Z80 peripheral devices all include a daisy chain priority interrupt structure that auto- 
matically supplies the programmed vector to the CPU during interrupt acknowledge. Refer to the Z80-PIO, 
Z80-SIO and Z80-CTC manuals for details. 
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9.0 HARDWARE IMPLEMENTATION EXAMPLES 

This chapter is intended to serve as a basic introduction to implementing systems with the Z80-CPU. 

MINIMUM SYSTEM 

Figure 9.0-1 is a diagram of a very simple Z-80 system. Any Z-80 system must include the following 
five elements: 

1) Five volt power supply 

2) Oscillator 

3) Memory devices 

4) I/O circuits 

5) CPU 



osc 



+5V 



RESET. 



+5 VOLT 
POWER SUPPLY 



Z80 
CPU 



A "A 9 



IT 

+5V GND 



MREQ 



CCT, 



f— C CE 



C 



DATA BUS 



a 



ADDRESS 
IN 



8KBIT 



FF ROM 



iORQ 



m 



_CE RD 
-°llORQ 



V 



DATA 
OUT 



Ml 



Z80- PIO 



B/A 



PORTA 



PORTB 



V 



-*0 

- A 1 



OUTPUT 
DATA 



INPUT 
DATA 



FIGURE 9.0-1 
MINIMUM Z80 COMPUTER SYSTEM 

Since the Z80-CPU only requires a single 5 volt supply, most small systems can be implemented using 
only this single supply. 

The oscillator can be very simple since the only requirement is that it be a 5 volt square wave. For 
systems not running at full speed, a simple RC oscillator can be used. When the CPU is operated near the 
highest possible frequency, a crystal oscillator is generally required because the system timing will not 
tolerate the drift or jitter that an RC network will generate. A crystal oscillator can be made from inverters 
and a few discrete components or monolithic circuits are widely available. 

The external memory can be any mixture of standard RAM, ROM, or PROM. In this simple example 
we have shown a single 8K bit ROM (IK bytes) being utilized as the entire memory system. For this 
example we have assumed that the Z-80 internal register configuration contains sufficient Read/Write 
storage so that external RAM memory is not required. 
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Every computer system requires I/O circuits to allow it to interface to the "real world." In this simple 
example it is assumed that the output is an 8 bit control vector and the input is an 8 bit status word. The 
input data could be gated onto the data bus using any standard tri-state driver while the output data could 
be latched with any type of standard TTL latch. For this example we have used a Z80-PIO for the I/O 
circuit. This single circuit attaches to the data bus as shown and provides the required 16 bits of TTL 
compatible I/O. (Refer to the Z80-PIO manual for details on the operation of this circuit.) Notice in this 
example that with only three LSI circuits, a simple oscillator and a single 5 volt power supply, a 
powerful computer has been implemented. 

ADDING RAM 

Most computer systems require some amount of external Read/Write memory for data storage and to 
implement a "stack." Figure 9.0-2 illustrates how 256 bytes of static memory can be added to the previous 
example. In this example the memory space is assumed to be organized as follows: 




Address 
0000H 



03FFH 
0400H 

04FFH 



ADDRESS BUS 





T^r MRQ RD 



10 WR 




DATA BUS 



FIGURE 9.0-2 
ROM & RAM IMPLEMENTATION EXAMPLE 



In this diagram the address space is described in hexidecimal notation. For this example, address bit Ajq 
separates the ROM space from the RAM space so that it can be used for the chip select function. For 
larger amounts of external ROM or RAM, a simple TTL decoder will be required to form the chip selects. 

MEMORY SPEED CONTROL 



For many applications, it may be desirable to use slow memories to reduce costs. The WAIT line on 
the CPU allows the Z-80 to operate with any speed memory. By referring back to section 4 you will notice 
that the memory access time requirements are most severe during the Ml cycle instruction fetch. All other 
memory accesses have an additional one half of a clock cycle to be completed. For this reason it may be 
desirable in some applications to add one wait state to the Ml cycle so that slower memories can be used. 
Figure 9.0-3 is an example of a simple circuit that will accomplish this task. This circuit can be changed to 
add a single wait state to any memory access as shown in Figure 9.0-4. 
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FIGURE 9.0-3 
ADDING ONE WAIT STATE TO AN M1 CYCLE 



FIGURE 9.0-4 
ADDING ONE WAIT STATE TO ANY MEMORY CYCLE 



INTERFACING DYNAMIC MEMORIES 

This section is intended only to sSrve as a brief introduction to interfacing dynamic memories. Each 
individual dynamic RAM has varying specifications that will require minor modifications to the description 
given here and no attempt will be made in this document to give details for any particular RAM. Separate 
application notes showing how the Z80-CPU can be interfaced to most popular dynamic RAM's are 
available from Zilog. 

Figure 9.0-5 illustrates the logic necessary to interface 8K bytes of dynamic RAM using 18 pin 4K 
dynamic memories. This figure assumes that the RAM's are the only memory in the system so that A^ * s 
used to select between the two pages of memory. During refresh time, all memories in the system must be 
read. The CPU provides the proper refresh address on lines Aq through A^. To add additional memory to 
the system it is necessary to only replace the two gates that operate on A^ w i* n a decoder that operates 
on all required address bits. For larger systems, buffering for the address and data bus is also generally 
required. 
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RFSH 
MREQ 
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ID — mI> 

-LJ~ 
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^ 



CE 



4Kx8 RAM ARRAY 



R/W 



DATA BUS 
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R/W 
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(OOOOtoOFFF) 



FIGURE 9.0-5 
INTERFACING DYNAMIC RAMS 
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10.0 SOFTWARE IMPLEMENTATION EXAMPLES 

10.1 METHODS OF SOFTWARE IMPLEMENTATION 

Several different approaches are possible in developing software for the Z-80 (Figure 10.1). First of 
all, Assembly Language or PL/Z may be used as the source language. These languages may then be trans- 
lated into machine language on a commercial time sharing facility using a cross-assembler or cross-compiler 
or, in the case of assembly language, the translation can be accomplished on a Z-80 Development System 
using a resident assembler. Finally, the resulting machine code can be debugged either on a time-sharing 
facility using a Z-80 simulator or on a Z-80 Development System which uses a Z80-CPU directly. 



SOURCE 
LANGUAGE 


TRANSLATION 


DEBUGGING 






RESIDENT ASSEMBLER 






ASSEMBLY 
LANGUAGE 




-** 






DEVELOPMENT 
SYSTEM 




















MACHINE 
LANGUAGE 










CROSS ASSEMBLER 














PL/Z OR OTHER 
HIGH LEVEL 
LANGUAGE 










SIMULATOR 










CROSS COMPILER 










FIGURE 10.1 





In selecting a source language, the primary factors to be considered are clarity and ease of program- 
ming vs. code efficiency. A high level language such as PL/Z with its machine independent constructs is 
typically better for formulating and maintaining algorithms, but the resulting machine code is usually 
somewhat less efficient than what can be written directly in assembly language. These tradeoffs can often 
be balanced by combining PL/Z and assembly language routines, identifying those portions of a task which 
must be optimized and writing them as assembly language subroutines. 

Deciding whether to use a resident or cross assembler is a matter of availability and short-term vs. 
long-term expense. While the initial expenditure for a development system is higher than that for a time- 
sharing terminal, the cost of an individual assembly using a resident assembler is negligible while the same 
operation on a time-sharing system is relatively expensive and in a short time this cost can equal the total 
cost of a development system. 

Debugging on a development system vs. a simulator is also a matter of availability and expense com- 
bined with operational fidelity and flexibility. As with the assembly process, debugging is less expensive on 
a development system than on a simulator available through time-sharing. In addition, the fidelity of the 
operating environment is preserved through real-time execution on a Z80-CPU and by connecting the I/O 
and memory components which will actually be used in the production system. The only advantage to 
the use of a simulator is the range of criteria which may be selected for such debugging procedures as trac- 
ing and setting breakpoints. This flexibility exists because a software simulation can achieve any degree of 
complexity in its interpretation of machine instructions while development system procedures have hard- 
ware limitations such as the capacity of the real-time storage module, the number of breakpoint registers 
and the pin configuration of the CPU. Despite such hardware limitations, debugging on a development 
system is typically more productive than on a simulator because of the direct interaction that is possible 
between the programmer and the authentic execution of his program. 



63 



10.2 SOFTWARE FEATURES OFFERED BY THE Z80-CPU 

The Z-80 instruction set provides the user with a large and flexible repetoire of operations with which 
to formulate control of the Z80-CPU. 

The primary, auxiliary and index registers can be used to hold the arguments of arithmetic and logical 
operations, or to form memory addresses, or as fast-access storage for frequently used data. 

Information can be moved directly from register to register; from memory to memory; from memory 
to registers; or from registers to memory. In addition, register contents and register/memory contents can 
be exchanged without using temporary storage. In particular, the contents of primary and auxilary registers 
can be completely exchanged by executing only two instructions, EX and EXX. This register exchange 
procedure can be used to separate the set of working registers between different logical procedures or to 
expand the set of available registers in a single procedure. 

Storage and retrieval of data between pairs of registers and memory can be controlled on a last-in 
first-out basis through PUSH and POP instructions which utilize a special stack pointer register, SP. This 
stack register is available both to manipulate data and to automatically store and retrieve addresses for 
subroutine linkage. When a subroutine is called, for example, the address following the CALL instruction 
is placed on the top of the push-down stack pointed to by SP. When a subroutine returns to the calling 
routine, the address on the top of the stack is used to set the program counter for the address of the next 
instruction. The stack pointer is adjusted automatically to reflect the current "top" stack position during 
PUSH, POP, CALL and RET instructions. This stack mechanism allows pushdown data stacks and sub- 
routine calls to be nested to any practical depth because the stack area can potentially be as large as 
memory space. 

The sequence of instruction execution can be controlled by six different flags (carry, zero, sign, 
parity /overflow, add-subtract, half-carry) which reflect the results of arithmetic, logical, shift and compare 
instructions. After the execution of an instruction which sets a flag, that flag can be used to control a 
conditional jump or return instruction. These instructions provide logical control following the manipula- 
tion of single bit, eight-bit byte (or) sixteen-bit data quantities. 

A full set of logical operations, including AND, OR, XOR (exclusive - OR), CPL (NOR) and NEG 
(two's complement) are available for Boolean operations between the accumulator and 1) all other eight-bit 
registers, 2) memory locations or 3) immediate operands. 

In addition, a full set of arithmetic and logical shifts in both directions are available which operate 
on the contents of all eight-bit primary registers or directly on any memory location. The carry flag can be 
included or simply set by these shift instructions to provide both the testing of shift results and to link 
register/register or register/memory shift operations. 

10.3 EXAMPLES OF USE OF SPECIAL Z80 INSTRUCTIONS 

A. Let us assume that a string of data in memory starting at location "DATA" is to be moved into 

another area of memory starting at location "BUFFER" and that the string length is 737 bytes. This 
operation can be accomplished as follows: 

; START ADDRESS OF DATA STRING 

; START ADDRESS OF TARGET BUFFER 

; LENGTH OF DATA STRING 

; MOVE STRING - TRANSFER MEMORY POINTED TO 

; BY HL INTO MEMORY LOCATION POINTED TO BY DE 

; INCREMENT HL AND DE, DECREMENT BC 

; PROCESS UNTIL BC = 0. 

1 1 bytes are required for this operation and each byte of data is moved in 21 clock cycles. 



LD 


HL , DATA ; 


LD 


DE , BUFFER ; 


LD 


BC , 737 ; 


LDIR 
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Let's assume that a string in memory starting at location "DATA" is to be moved into another area 
of memory starting at location "BUFFER" until an ASCII $ character (used as string delimiter) is 
found. Let's also assume that the maximum string length is 132 characters. The operation can be 
performed as follows: 

STARTING ADDRESS OF DATA STRING 

STARTING ADDRESS OF TARGET BUFFER 

MAXIMUM STRING LENGTH 

STRING DELIMITER CODE 

COMPARE MEMORY CONTENTS WITH DELIMITER 

GO TO END IF CHARACTERS EQUAL 

MOVE CHARACTER (HL) to (DE) 

INCREMENT HL AND DE, DECREMENT BC 

GO TO "LOOP" IF MORE CHARACTERS 

OTHERWISE, FALL THROUGH 

NOTE: P/V FLAG IS USED 

TO INDICATE THAT REGISTER BC WAS 

DECREMENTED TO ZERO. 



LD 


HL , DATA 


LD 


DE , BUFFER 


LD 


BC , 132 


LD 


A,T 


LOOP:CP 


(HL) 


JR 


Z , END - $ 


LDI 





JP 



END: 



PE , LOOP 



19 bytes are required for this operation. 

Let us assume that a 16-digit decimal number represented in packed BCD format (two BCD digits/ 
byte) has to be shifted as shown in the Figure 10.2 in order to mechanize BCD multiplication or 
division. The operation can be accomplished as follows: 



LD 
LD 
XOR 
ROTAT: RLD 

INC 
DJNZ 



HL , DATA 
B , COUNT 
A 



HL 
ROTAT 



ADDRESS OF FIRST BYTE 

SHIFT COUNT 

CLEAR ACCUMULATOR 

ROTATE LEFT LOW ORDER DIGIT IN ACC 

WITH DIGITS IN (HL) 

ADVANCE MEMORY POINTER 

DECREMENT B AND GO TO ROTAT IF 

B IS NOT ZERO, OTHERWISE FALL THROUGH 



11 bytes are required for this operation. 



^ 



^ 



** 



-&. 



~*± 



§5 



** 



^ 






FIGURE 10.2 
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D. Let us assume that one number is to be subtracted from another and a) that they are both in packed 
BCD format, b) that they are of equal but varying length, and c) that the result is to be stored in the 
location of the minuend. The operation can be accomplished as follows: 



LD 


HL,ARG1 


LD 


DE , ARG2 


LD 


B , LENGTH 


AND 


A 


SUBDEC:LD 


A , (DE) 


SBC 


A , (HL) 


DAA 




LD 


(HL),A 


INC 


HL 


INC 


DE 


DJNZ 


SUBDEC - $ 



ADDRESS OF MINUEND 

ADDRESS OF SUBTRAHEND 

LENGTH OF TWO ARGUMENTS 

CLEAR CARRY FLAG 

SUBTRAHEND TO ACC 

SUBTRACT (HL) FROM ACC 

ADJUST RESULT TO DECIMAL CODED VALUE 

STORE RESULT 

ADVANCE MEMORY POINTERS 

; DECREMENT B AND GO TO "SUBDEC" IF B 
; NOT ZERO, OTHERWISE FALL THROUGH 



17 bytes are required for this operation. 



10.4 EXAMPLES OF PROGRAMMING TASKS 



The following program sorts an array of numbers each in the range (0,255) into ascending order using 
a standard exchange sorting algorithm. 
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01/22/76 11:14:37 BUBBLE LISTING 

LOC OBJ CODE STMT SOURCE STATEMENT 



Jr rWjrJ_/ 1 



0000 
0003 
0005 
0006 
0007 
000B 
000E 
000F 
0012 
0013 
0015 
0018 
001B 
001D 
001F 



222600 

CB84 

41 

05 

DD2A2600 

DD7E00 

57 

DD5E01 

93 

3008 

DD7300 

DD7201 

CBC4 

DD23 

10EA 



0021 CB44 
0023 20DE 
0025 C9 

0026 
0026 



1 ; *** STANDARD EXCHANGE (BUBBLE) SORT ROUTINE *** 

2 ; 

3 ; AT ENTRY: HL CONTAINS ADDRESS OF DATA 

4 C CONTAINS NUMBER OF ELEMENTS TO BE SORTED 

5 (1<C<256) 
6 

AT EXIT: DATA SORTED IN ASCENDING ORDER 



7 
8 
9 

10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 
35 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 



USE OF REGISTERS 



REGISTER CONTENTS 



A 

B 

C 

D 

E 

H 

L 

IX 

IY 

SORT: 
LOOP: 



NEXT: 



NOEX: 



TEMPORARY STORAGE FOR CALCULATIONS 

COUNTER FOR DATA ARRAY 

LENGTH OF DATA ARRAY 

FIRST ELEMENT IN COMPARISON 

SECOND ELEMENT IN COMPARISON 

FLAG TO INDICATE EXCHANGE 

UNUSED 

POINTER INTO DATA ARRAY 

UNUSED 



FLAG: 
DATA: 



LD 

RES 

LD 

DEC 

LD 

LD 

LD 

LD 

SUB 

JR 

LD 

LD 

SET 

INC 

DJNZ 

BIT 

JR 

RET 

EQU 

DEFS 

END 



(DATA), HL 

FLAG,H 

B,C 

B 

IX, (DATA) 

A, (IX) 

D, A 

E, (IX+1) 
E 

NC, NOEX-$ 

(IX), E 

(IX+1),D 

FLAG,H 

IX 

NEXT-$ 

FLAG,H 
NZ,LOOP-$ 



SAVE DATA ADDRESS 
INITIALIZE EXCHANGE FLAG 
INITIALIZE LENGTH COUNTER 
ADJUST FOR TESTING 
INITIALIZE ARRAY POINTER 
FIRST ELEMENT IN COMPARISON 
TEMPORARY STORAGE FOR ELEMENT 
SECOND ELEMENT IN COMPARISON 
COMPARISON FIRST TO SECOND 
IF FIRST > SECOND, NO JUMP 
EXCHANGE ARRAY ELEMENTS 

RECORD EXCHANGE OCCURRED 
POINT TO NEXT DATA ELEMENT 
COUNT NUMBER OF COMPARISONS 
REPEAT IF MORE DATA PAIRS 
DETERMINE IF EXCHANGE OCCURRED 
CONTINUE IF DATA UNSORTED 
OTHERWISE, EXIT 

DESIGNATION OF FLAG BIT 
; STORAGE FOR DATA ADDRESS 
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B. The following program multiplies two unsigned 16 bit integers and leaves the result in the HL register 
pair. 



01/22/76 11:32:36 MULTIPLY LISTING 

LOC OBJ CODE STMT SOURCE STATEMENT 



PAGE 1 



0000 




1 






2 






3 






4 






5 






6 






7 






8 






9 






10 






11 






12 






13 






14 






15 






16 






17 


0000 


0610 


18 


0002 


4A 


19 


0003 


7B 


20 


0004 


EB 


21 


0005 


210000 


22 


0008 


CB39 


23 


000A 


IF 


24 

25 


000B 


3001 


26 


000D 


19 


27 
28 


OOOE 


EB 


29 


OOOF 


29 


30 


0010 


EB 


31 


0011 


10F5 


32 


0013 


C9 


. 33 
34 



MULT:; 



MLOOP: 



NOADD: 



UNSIGNED SIXTEEN BIT INTEGER MULTIPLY. 
ON ENTRANCE: MULTIPLIER IN DE. 

MULTIPLICAND IN HL. 

ON EXIT: RESULT IN HL. 

REGISTER USES: 



H 
L 
D 
E 
B 
C 
A 

LD 

LD 

LD 

EX 

LD 

SRL 

RRA 

JR 
ADD 

EX 
ADD 

EX 
DJNZ 
RET; 
END; 



HIGH ORDER PARTIAL RESULT 
LOW ORDER PARTIAL RESULT 
HIGH ORDER MULTIPLICAND 
LOW ORDER MULTIPLICAND 
COUNTER FOR NUMBER OF SHIFTS 
HIGH ORDER BITS OF MULTIPLIER 
LOW ORDER BITS OF MULTIPLIER 



B, 16; 

C,D; 

A,E; 

DE,HL; 

HL, 0; 

C; 



NCNOADD- 
HL, DE; 

DE,HL; 
HL, HL; 
DE, HL; 
MLOOP-S; 



NUMBER OF BITS- INITIALIZE 
MOVE MULTIPLIER 

MOVE MULTIPLICAND 

CLEAR PARTIAL RESULT 

SHIFT MULTIPLIER RIGHT 

LEAST SIGNIFICANT BIT IS 

IN CARRY. 

IF NO CARRY, SKIP THE ADD. 

ELSE ADD MULTIPLICAND TO 

PARTIAL RESULT. 

SHIFT MULTIPLICAND LEFT 

BY MULTIPLYING IT BY TWO. 

REPEAT UNTIL NO MORE BITS. 
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Absolute Maximum Ratings 



Temperature Under Bias 
Storage Temperature 
Voltage On Any Pin 

with Respect to Ground 
Power Dissipation 



Specified operating range. 
-65°C to+150°C 
-0.3Vto+7V 

1.5W 



*Comment 

Stresses above those listed under "Absolute 
Maximum Rating" may cause permanent 
damage to the device. This is a stress rating 
only and functional operation of the device 
at these or any other condition above those 
indicated in the operational sections of this 
specification is not implied. Exposure to 
absolute maximum rating conditions for 
extended periods may affect device reliability. 



Z80-CPU D.C. Characteristics 



T* = 0°C to 70°C, V = 5V + 5% unless otherwise sped 


fied 










Symbol 


Parameter 


Min. 


Typ. 


Max. 


Unit 


Test Condition 


V 1LC 


Clock Input Low Voltage 


-0.3 




0.45 


V 




V IHC 


Clock Input High Voltage 


V cc -6 




V cc + - 3 


V 




V 1L 


Input Low Voltage 


-0.3 




0.8 


V 




V IH 


Input High Voltage 


2.0 




V cc 


V 




V OL 


Output Low Voltage 






0.4 


V 


Iqi =1.8mA 


V OH 


Output High Voltage 


"2.4 






V 


1 OH = -250M 


'cc 


Power Supply Current 






150 


mA 




<L1 


Input Leakage Current 






10 


nA 


V IN =0toV cc 


'loh 


Tri-State Output Leakage Current in Float 






10 


HA 


V OUT =2.4toV cc 


■lol 


Tri-State Output Leakage Current in Float 






-10 


HA 


V OUT =0.4V 


'ld 


Data Bus Leakage Current in Input Mode 






±10 


HA 


0<V IN< V cc 



Note: For Z80-CPU all AC and DC characteristics remain the 
same for the military grade parts except I . 



I = 200 mA 



Capacitance 



T A = 25 C, f = 1 MHz, 
unmeasured pins returned to ground 



Symbol 


Parameter 


Max. 


Unit 


c* 


Clock Capacitance 


35 


PF 


C IN 


Input Capacitance 


5 


pF 


C OUT 


Output Capacitance 


10 


P F 



Z80-CPU 

Ordering Information 

C — Ceramic 

P - Plastic 

S - Standard 5V ±5% 0° to 70°C 

E - Extended 5V ±5% -40° to 85°C 

M - Military 5V ±10% -55° to 12S°C 



Z80A-CPU D.C. Characteristics 

T^ = 0°C to 70°C. V = 5V ± 5'V unless otherwise specified 



Symbol 


Parameter 


Min. 


Typ. 


Max. 


Unit 


Test Condition 


V 1LC 


Clock Input Low Voltage 


-0.3 




0.45 


V 




V IHC 


Clock Input High Voltage 


V cc -6 




V + 3 
cc - J 


V 




V 1L 


Input Low Voltage 


-0.3 




0.8 


\ 




V IH 


Input High Voltage 


2.0 




v, c 


V 




V OL 


Output Low Voltage 






0.4 


V 


I QL = 1.8mA 


V OH 


Output High Voltage 


2.4 






V 


l OH = -2?0M 


•cc 


Power Supply Cut rent 




90 


200 


mA 




»LI 


Input Leakage Current 






10 


uA 


V, N =0toV cc 


'loh 


Tri-State Output Leakage Current in Float 






10 


M 


V OUT =2.4toV cc 


'l.OL 


Tri-State Output Leakage Current in Float 






-10 


MA 


V OUT =0.4V 


'ld 


Data Bus Leakage Current in Input Mode 






±10 


M 


o<v 1N <v cc 



Capacitance 

T A = 25°C,f= 1 MHz. 

unmeasured pins returned to ground 



Symbol 


Parameter 


Max. 


Unit 


c, p 


Clock Capacitance 


35 


PH" 


C '|N 


Input Capacitance 


5 


P F 


c oin 


Output Capacitance 


10 


pF 



Z80A-CPU 
Ordering Information 



C — Ceramic 

P - Plastic 

S - Standard 5V ±5% 0° to 70°C 
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a.i_x, \^n<ir«ictcristics 



Z80CPU 



T A = 0°C to 70°C, Vcc = +5V ± 5%, Unless Otherwise Noted. 



Signal 


Symbol 


Parameter 


Min 


Max 


Unit 


Test Condition 


<1> 


t c 

1 W ('I»H) 

t w (<l>L) 


Cluck Period 

Clock Pulse Width, Clock High 
Clock Pulse Width, Clock Low 
Clock Rise and Fall Time 


.4 


112] 


/usee 




180 


[E] 


nsec 


180 


2000 


nsec 




30 


nsec 


^3-15 


'D(AD) 
l F(AD) 

'aem 
•aci 
l ca 
l caf 


Address Output Delay 

Delay to Float 

Address Stable Prior to MREQ (Memory Cycle) 

Address Stable Prior to IORQ, RD or WR (1/0 Cycle) 

Address Stable from KB, WR^IORQ or MREQ 

Address Stable From RD or WR During Float 




14S 


nsec 


C L = 50pF 




110 


nsec 


111 




nsec 


121 




nsec 


13] 




nsec 


[4] 




nsec 


D 0-7 


'D(D) 
'F(D) 
•S*(D) 
l S*(D) 

'dcm 

«dci 

•cdf 


Data Output Delay 

Delay to Float During Write Cycle 

Data Setup Time to Rising Edge of Clock During Ml Cycle 

Data Setup Time to Falling Edge of Clock During M2 to M5 

Data Stable Prior to WR (Memory Cycle) 

Data Stable Prior to WR (I/O Cycle) 

Data Stable From WR 




230 


nsec 


C L =50pF 




90 


nsec 


50 




nsec 


60 




nsec 


[5] 




nsec 


16] 




nsec 


[71 








l H 


Any Hold Time for Setup Time 







nsec 






l DL*(MR) 
<DH<J>(MR) 
! DH*(MR) 
l w (MRL) 
'w (MRH) 


MREQ Delay From Falling Edge of Clock, MREQ Low 
MREQ Delay From Rising Edge of Clock, MREQ High 
MREQ Delay From Falling Edge of Clock, MRPJ High 
Pulse Width, MREQ Low 
Pulse Width, MREQ High 




100 


nsec 


C L = 50pF 




100 


nsec 


MREQ 




100 


nsec 


18] 




nsec 


[9] 




nsec 


iORQ 


l DL*(IR) 
l DL* (IR) 
l DH* (IR) 
*DH* (IR) 


IORQ Delay From Rising Edge of Clock, IORQ Low 
IORQ Delay From Falling Edge of Clock, IORQ Low 
IORQ Delay From Rising Edge of Clock, IORQ High 
IORQ Delay From Falling Edge of Clock, IORQ High 




90 


nsec 


C L = 50pF 




110 


nsec 




100 


nsec 




110 


nsec 


RD 


l DL* (RD) 
l DL* (RD) 
<DH* (RD) 
l DH* (RD) 


RD Delay From Rising Edge of Clock, RD Low 
RD Delay From Falling Edge of Clock, RD Low 
RD Delay From Rising Edge of Clock, RD High 
RD Delay From Falling Edge of Clock, RD High 




100 


nsec 


C L = 50pF 




130 


nsec 




100 


nsec 




110 


nsec 


WR 


<DL* (WR) 
'DL* (WR) 
'DH* (WR) 
>w (WRL) 


WR Delay From Rising Edge of Clock, WR Low 
WR Delay From Falling Edge of Clock, WR Low 
WR Delay From Falling Edge of Clock, WR High 
Pulse Width, WR Low 




80 


nsec 


C L = 50pF 




90 


nsec 




100 


nsec 


110] 




nsec 


Ml 


l DL(MI) 
l DH(Ml) 


Ml Delay From Rising Edge of Clock, Mf Low 

Ml Delay From Rising Edge of Clock, Ml High 




130 


nsec 


C L = 50pF 




130 


nsec 


RFSH 


l DL(RF) 
! DH (RF) 


RFSH Delay From Rising Edge of Clock, RFSH Low 
RFSH Delay From Rising Edge of Clock, RFSH High 




180 


nsec 


C L = 50pF 




150 


nsec 


WATT 


's(WT) 


WAIT Setup Time to Falling Edge of Clock 


70 




nsec 




halt 


l D (HT) 


HALT Delay Time From Falling Edge of Clock 




300 


nsec 


C L = 50pF 


INT 


<s (IT) 


INT Setup Time to Rising Edge of Clock 


80 




nsec 




NMT 


l w(NML) 


Pulse Width, NM1 Low 


80 




nsec 






l s(BQ) 




80 




nsec 




BUSRQ 


BUSRQ Setup Time to Rising Edge of Clock 




'DL(BA) 
'DH(BA) 






120 


nsec 


C, = 50pF 


BUSAK Delay From Rising Edge of Clock, BUSAK Low 
BUSAK Delay From Falling Edge of Clock, BUSAK High 


BUSAK 




110 


nsec 




h (RS) 




90 




nsec 




RESET 


RESET Setup Time to Rising Edge of Clock 




'F(C) 


Delay to Float (MREQ, IORQ, RD and WR) 




100 


nsec 






'mr 


Ml Stable Prior to IORQ (Interrupt Ack.) 


111] 




nsec 





f ,2 l t c =t w(*H) +, w(*L) + t r +t f 



I 1 ' t acm = t w(4>H) + ! f~ 75 
[2] t acj = t c -80 



(31 «=» = « 



ca " l w(*L) T l r 



+ t -40 



'caf _t w(*L) + , r" 60 



[5] t 



dcm " 



■210 



m t 



dci - l w(*L) T t r 



+ t -210 



m t , f =t 



cdf -l w(*L) r 



+ L-80 



[8] t 
[9] t 



w(MRL)~ l c' 



w(MRH)" l w(*H)' ri f 



+ tr-30 



[<°] VWRy^c- 40 



I'M 'mr^'c + 'w^H)^- 80 



NOTES: 

A. Data should be enabled onto the CPU d ata bus when RD is active. During interrupt acknowledge data 

should be enabled when Ml and IORQ are both active. ""» 

B. All control signals are internally synchronized, so they may be totally asynchronous with respect 
to th e clock . 

C. The RESET signal must be active for a minimum of 3 clock cycles. 

D. Output Delay vs. Loaded Capacitance 

TA = 70°C Vcc = +5V ±5'* 

Add 1 Onsec delay for each 50pf increase in load up to a maximum of 200pf for the data bus & lOOpf for 
address & control lines 

E. Although static by design, testing guarantees t^^uj of 200 /isec maximum 



c i. -r- 



Load circuit for Output 
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A.C. Timing Diagram 



Timing measurements are made at the following 
voltages, unless otherwise specified: 




"1" "0" 

CLOCK V CC -.6V .45V 

OUTPUT 2.0 V .8 V 

INPUT 2.0 V .8 V 

FLOAT AV +0.5V 



A 0-A15 



v 0-15 



'0-7 



\N 



.OUT 



D (AD) 



M1 



RFSH 



MREQ 



RD 



VVR 



IORQ 



RD 



WR 



WAIT 



HALT 



INT 



NMI 



BUSRQ 



BUSAK 



RESET 



•WWH.) 



\ 



FX 



'OUMI) 



imu\nru\n 



/x j^\-_ 



— l S<MD}— 



X DH(M1)- 



■4V 



'DL(RF)- 



\ 



■^ 

'DL'I'(RD) l DH<l>(RD)- 

w 



X S(WT) 



t DL<l>(IR) 



X 



l DH<I> (iR)- 



X 



X 



/ 



/ m: 



■-tt-4 — 

-Vr 



X 



l DH>I>(MR) 



[ DH(RF) 

1 



!W(MRL) 



•WJMRH) 



/ 



*t X 



zx 



l S (IT 



l W (NMD 




'DSD) 



■Vi- 
T4-4S- 



\ 
\ 



4V- 



-tv 



-fr 



l S<HD)-~- 



___^X 



l DH<l>(MR)-— 



'DL'I'IWR) 



DH<l><R0)— 



dcm- 
^L'lMIR) 



_X -- l W(WRL)-~ 



: X-^ 



l DH<l>(IR) 



'DL'I'(RD) 



X 



"JT' X 



l DH<l»(WR)-*- 



[ D (HT) 



X^^ 

xz 




,K 





DC 



F(C) 



l F(D) 



r 



l DH'I>(WR 



X 



r R) 



/-,.../ 




X "X 
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A.C Characteristics 



Z80A CPU 



T A = 0°C to 70°C, V C c = +5V ± 5%, Unless Otherwise Noted. 



Signal 


Symbol 


Parameter 


Min 


Max 


Unit 


Test Condition 


<1> 


'w (*H) 

t w (*L) 

'r, 1" 


Clock Period 

Clock Pulse Width, Clock High 
Clock Pulse Width, Clock Low 
Clock Rise and Fall Time 


.25 


1121 


H$ec 




110 


IK] 


nsec 


110 


2000 


nsec 




30 


nsec 


Vis 


'D(AD) 
'F(AD) 

acm 
'aci 
'ca 
l caf 


Address Output Delay 

Delay to Float 

Address Stable Prior to MREQ (Memory Cycle) 

Address Stable Prior to IORQ, RD or WR (I/O Cycle) 

Address Stable from RD. WR^ IORQ or MREQ 

Address Stable From RD or WR During Float 




110 


nsec 


C L = 50pF 




90 


nsec 


111 




nsec 


121 




nsec 


131 




nsec 


(4) 




nsec 


D 0-7 


«D(D) 

'F(D) 

'S* (D) 

'S* (D) 

'dcm 

'dci 

'cdf 


Data Output Delay 

Delay to Float During Write Cycle 

Data Setup Time to Rising Edge of Clock During Ml Cycle 

Data Setup Time to Falling Edge of Clock During M2 to M5 

Data Stable Prior to WR (Memory Cycle) 

Data Stable Prior to WR (I/O Cycle) 

Data Stable From WR 




150 


nsec 


C l =50pF 




90 


nsec 


35 




nsec 


50 




nsec 


[51 




nsec 


[61 




nsec 


[71 








'H 


Any Hold Time for Setup Time 







nsec 






l DL*(MR) 
'DH* (MR) 
'DH* (MR) 
'w (MRL) 
'w (MRH) 


MREQ Delay From Falling Edge of Clock, MREQ Low 
MREQ Delay From Rising Edge of Clock, MREQ High 
MREQ Delay From Falling Edge of Clock, MREQ High 
Pulse Width, MREQ Low 
Pulse Width, MREQ High 




85 


nsec 


C L = 50pF 




85 


nsec 


MREQ 




85 


nsec 


[81 




nsec 


[91 




nsec 


IORQ 


'DL* (IR) 
'DL* (IR) 
'DH* (IR) 
'DH* (IR) 


IORQ Delay From Rising Edge of Clock, IORQ Low 
IORQ Delay From Falling Edge of Clock, IORQ Low 
IORQ Delay From Rising Edge of Clock, IORQ High 
IORQ Delay From Falling Edge of Clock, IORQ High 




75 


nsec 


C L = 50pF 




85 


nsec 




85 


nsec 




85 


nsec 


RD 


l DL* (RD) 
'DL* (RD) 
'DH* (RD) 
'DH* (RD) 


RD Delay From Rising Edge of Clock, RD Low 
RD Delay From Falling Edge of Clock, RD Low 
RD Delay From Rising Edge of Clock, RD High 
RD Delay From Falling Edge of Clock, RD High 




85 


nsec 


C L = 50pF 




95 


nsec 




85 


nsec 




85 


nsec 


WR 


'DL* (WR) 
'DL*(WR) 
'DH* (WR) 
'w(WRL) 


WR Delay From Rising Edge of Clock, WR Low 
WR Delay From Falling Edge of Clock, WR Low 
WR Delay From Falling Edge of Clock, WR High 
Pulse Width, WR Low 




65 


nsec 


C L =50pF 




80 


nsec 




80 


nsec 


[10] 




nsec 


MT 


'DL(Ml) 
'DH(M1) 


Ml Delay From Rising Edge of Clock, Ml Low 
Ml Delay From Rising Edge of Clock, Ml High 




100 


nsec 


C L =50pF 




100 


nsec 


RFSH 


'DL (RF) 
'DH (RF) 


RFSH Delay From Rising Edge of Clock, RFSH Low 
RFSH Delay From Rising Edge of Clock, RFSH High 




130 


nsec 


C L = 50 P F 




120 


nsec 


waTT 


's(WT) 


WAIT Setup Time to Falling Edge of Clock 


70 




nsec 




HALT 


'D (HT) 


HALT Delay Time From Falling Edge of Clock 




300 


nsec 


C L = 50pF 


INT 


's(IT) 


INT Setup Time to Rising Edge of Clock 


80 




nsec 




NMl 


l w (NML) 


Pulse Width, NMl Low 


80 




nsec 






's(BQ) 




50 




nsec 




BUSRQ 


BUSRQ Setup Time to Rising Edge of Clock 




'DL(BA) 
'DH (BA) 






100 


nsec 


C L = 50pF 


BUSAK Delay From Rising Edge of Clock, BUSAK Low 
BUSAK Delay From Falling Edge of Clock, BUSAK High 


BUSAK 




100 


nsec 




's (RS) 




60 




nsec 




RESET 


RESET Setup Time to Rising Edge of Clock 




'F(C) 


Delay to Float (MREQ, IORQ, RD and WR) 




80 


nsec 






'mr 


Ml Stable Prior to IORQ (Interrupt Ack.) 


[111 




nsec 





c - 'w(*H) + 'w(*L) + 'r + 'f 



t>] 'acm""'w(*H) + t f- 65 

I 2 ) 'aci = 'c- 70 

[3] tca^w^D + tr- 50 

M 'caf=«w(*L) + 'r- 45 



[5] t 



dem 



= t -170 



[6] U M = t 



dci = t w(*L) + t r" 170 



m t , f =t 



+ 1 - 70 



cdf~ l w(*L) r 

m ' w (MRL) = 'c- 30 

f 9 l 'w(MRH) = t w(*H) + t f- 20 



tl0] *w(WRL) = *c " : 



■30 



l"! Vnr-^c + VwO + tf- 65 



TEST POINT 



B. 



Data should be enabled onto the CPU d ata bus when RD is active. During interrupt acknowledge data 
should be enabled when Ml and IORQ are both active. 

All control signals are internally synchronized, so they may be totally asynchronous with respect 
to the clock. 



C. The RESET signal must be active for a minimum of 3 clock cycles. 

D. Output Delay vs. Loaded Capacitance 

TA = 70°C Vcc = +5V ±5% 

Add lOnsec delay for each 50pf increase in load up to maximum of 200pf for data bus and lOOpf for 

address & control lines. 

E. Although static by design, testing guarantees W^jj, of 200 fisec maximum 



C L -y 



Load circuit for Output 
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WW 12.C 


1 


DECIY 


*??■ Z80-CPU 
Zllog INSTRUCTION SET 


DECss 
Dl 


ADCHL, ss 


Add with Carry Reg. pair ss to HL 


DJNZe 


ADC A, s 


Add with carry operand s to Ace. 


El 


ADD A, n 


Add value n to Ace. 


EX (SP), HL 


ADD A, r 


Add Reg. r to Ace. 


EX (SP), IX 


ADD A, (HL) 


Add location (HL) to Ace. 


EX (SP), IY 


ADD A, (IX+d) 


Add location (IX+d) to Ace. 


EXAF, AF' 


ADD A, (lY+d) 


Add location (lY+d) to Ace. 




ADDHL,ss 


Add Reg. pair ss to HL 


EXDE, HL 


ADD IX, pp 
ADD IY, rr 


Add Reg. pair pp to IX 
Add Reg. pair rr to IY 


EXX 


ANDs 


Logical 'AND' of operand s and Ace. 




BITb, (HL) 


Test BIT b of location (HL) 


HALT 


BIT b, (IX+d) 


Test BIT b of location (IX+d) 


IMO 


BITb, (lY+d) 


Test BIT b of location (lY+d) 


IM1 


BIT b, r 


Test BIT b of Reg. r 


IM2 


CALL cc, nn 


Call subroutine at location nn if 
condition cc if true 


INA,(n) 


CALL nn 


Unconditional call subroutine at 
location nn 


IN r, (C) 


CCF 


Complement carry flag 


INC(HL) 


CPs 


Compare operand s with Ace. 


INC IX 


CPD 


Compare location (HL) and Ace. 


INC (IX+d) 



decrement HL and BC 

CPDR Compare location (HL) and Ace. 

decrement HL and BC, repeat 
until BC=0 

CPI Compare location (HL) and Ace. 

increment HL and decrement BC 

CPIR Compare location (HL> and Ace. 

increment HL, decrement BC 
repeat until BC=0 

CP L Complement Ace. ( 1 's comp) 

DAA Decimal adjust Ace. 

DEC m Decrement operand m 

DEC IX Decrement IX 



INDR 



INI 



Decrement IY 

Decrement Reg. pair ss 

Disable interrupts 

Decrement B and Jump 
relative if B/0 

Enable interrupts 

Exchange the location (SP) and HL 

Exchange the location (SP) and IX 

Exchange the location (SP) and IY 

Exchange the contents of AF 
and AF' 

Exchange the contents of DE 
andHL 

Exchange the contents of BC, DE, 
HL with contents of BC, DE', HL' 
respectively 

HALT (wait for interrupt or reset) 

Set interrupt mode 

Set interrupt mode 1 

Set interrupt mode 2 

Load the Ace. with input from 
device n 

Load the Reg. r with input from 
device (C) 

Increment location (HL) 

Increment IX 

Increment location (IX+d) 

Increment IY 



INC (lY+d) 


Increment location (lY+d) 


INCr 


Increment Reg. r 


INCss 


Increment Reg. pair ss 


IND 


Load location (HL) with input 




from port (C), decrement HL 




and B 



Load location (HL) with input 
from port (C), decrement HL and 
decrement B, repeat until B=0 

Load location (HL) with input 
from port (C); and increment HL 
and decrement B 
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INIR Load location (HL) with input 

from port (C), increment HL 
and decrement B, repeat until 
B=0 

JP (HL) Unconditional Jump to (HL) 

JP ( I X) Unconditional Ju mp to ( I X) 

JP (IY) Unconditonal Jump to (IY) 

JP cc, nn Jump to location nn if 

condition cc is true 

JP nn Unconditional jump to location 

nn 

JP C, e Jump relative to PC+e if carry=1 

JR e Unconditional Jump relative 

to PC+e 

JP NC, e Jump relative to PC+e if carry=Q 

JR NZ, e Jump relative to PC+e if non 

zero (Z=0) 

JR Z, e Jump relative to PC+e if zero (Z=1) 

LD A, (BC) Load Ace. with location (BC) 

LDA, (DE) Load Ace. with location (DE) 

LD A, I Load Ace. with I 

LD A, (nn) Load Ace. with location nn 

LD A, R Load Ace. with Reg. R 

LD (BC), A Load location (BC) with Ace. 

LD (DE), A Load location (DE) with Ace. 

LD (HL), n Load location (HL) with value n 

LD dd, nn Load Reg. pair dd with value nn 

LD HL, (nn) Load HL with location (nn) 

LD (HL), r Load location (HL) with Reg. r 

LD I, A Load I with Ace. 

LF IX, nn Load IX with value nn 

LD IX, (nn) Load IX with location (nn) 

LD (IX+d), n Load location (IX+d) with value n 

LD (IX+d) , r Load location (IX+d) with Reg. r 

LD IY, nn Load I Y with value nn 

LD IY, (nn) Load IY with location (nn) 

LD (lY+d), n Load location (lY+d) with value n 

LD (lY+d), r Load location (lY+d) with Reg. r 



LD (nn), A Load location (nn) with Ace. 

LD (nn), dd Load location (nn) with Reg. pair dd 

LD (nn), HL Load location (nn) with HL 

LD (nn), IX Load location (nn) with IX 

LD (nn), IY Load location (nn) with IY 

LD R, A Load R with Ace. 

LD r, (HL) Load Reg. r with location (HL) 

LD r, (IX+d) Load Reg. r with location (IX+d) 

LD r, (lY+d) Load Reg. r with location (lY+d) 

LD r, n Load Reg. r with value n 

LD r, r' Load Reg. r with Reg. r' 

LDSP, HL Load SP with HL 

LDSP, IX Load SP with IX 

LD SP, IY Load SP with IY 

LDD Load location (DE) with location 

(HL), decrement DE, HL and BC 

LDDR Load location (DE) with location 

(HL), decrement DE, HL and BC; 
repeat until BC=0 

LDI Load location (DE) with location 

(HL), increment DE, HL, 
decrement BC 

LDIR Load location (DE) with location 

(HL), increment DE, HL, 
decrement BC and repeat until 
BC=0 

NEG Negate Ace. (2's complement) 

NOP No operation 

OR s Logical 'OR' or operand s and Ace. 

OTDR Load output port (C) with location 

(HL) decrement HL and B, repeat 

until B=0 

OTIR Load output port (C) with location 

(HL), increment HL, decrement B, 
repeat until B=0 

OUT (C), r Load output port (C) with Reg. r 

OUT (n), A Load output port ( n) with Ace. 

OUTD Load output port (C) with location 

(HL), decrement HL and B 

OUTI Load output port (C) with location 

(HL), increment HL and decrement 
B 
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POP IX 


Load IX with top of stack 


RR m 


POPIY 


Load IY with top of stack 


RRA 


POPqq 


Load Reg. pair qq with top of stack 


RRCm 


PUSH IX 


Load IX onto stack 


RRCA 


PUSH IY 


Load IY onto stack 


RRD 


PUSH qq 


Load Reg. pair qq onto stack 




RES b, m 


Reset Bit b of operand m 


RSTp 


RET 


Return from subroutine 


SBC A, s 


RET cc 


Return from subroutine if condition 






cc is true 


SBCHL.ss 


RETI 


Return from interrupt 




RETN 


Return from non maskable interrupt 


SCF 


RLm 


Rotate left through carry operand m 


SET b, (HL) 


RLA 


Rotate left Ace. through carry 


SET b, (IX+d) 


RLC(HL) 


Rotate location (HL) left circular 


SETb,(IY+d) 


RLC(IX+d) 


Rotate location (IX+d) left circular 


SET b, r 


RLC(IY+d) 


Rotate location (lY+d) left circular 


SLAm 


RLCr 


Rotate Reg. r left circular 


SRAm 


RLCA 


Rotate left circular Ace. 


SRL m 


RLD 


Rotate digit left and right between 


SUBs 




Ace. and location (HL) 


XORs 



Rotate right through carry operand m 

Rotate right Ace. through carry 

Rotate operand m right circular 

Rotate right circular Ace. 

Rotate digit right and left between 
Ace. and location (HL) 

Restart to location p 

Subtract operand s from Ace. with 
carry 

Subtract Reg. pair ss from HL with 
carry 

Set carry flag (C=1) 

Set Bit b of location (HL) 

Set Bit b of location (IX+d) 

Set Bit b of location (lY+d) 

Set Bit b of Reg. r 

Shift operand m left arithmetic 

Shift operand m right arithmetic 

Shift operand m right logical 

Subtract operand s from Ace. 

Exclusive 'OR' operand s and Ace. 
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